草庐IT

turn-by-turn

全部标签

MySQL Group by Sum by Day

我有一张tableidintpkauto_inc|createdint(11)|amountint|user_idint我想创建一个按天分组的行列表,总计金额字段。我试过这个:SELECTcreated,sum(amount)asamount,idFROMtotal_logWHEREuser_id=$this->user_idGROUPBYDAY(created)这不会给出正确的结果。他们被分组到一排。日期由dd/mm/yyyy格式保存为unix时间戳,如1349046000 最佳答案 SELECTDATE(FROM_UNIXTIM

mysql - 如何使用 LEFT JOIN 而不是 GROUP BY 来查询多个用户使用的电子邮件?

假设我有一个名为user_table的表:user_tableidfirst_namelast_namegenderemailcreated_at我该如何编写一个查询,列出多个用户使用的电子邮件?编辑:用LEFTJOIN代替GROUPBY能达到同样的结果吗? 最佳答案 SELECTemailFROMuser_tableGROUPBYemailHAVINGCOUNT(*)>1或者,您可以使用INNERJOIN:SELECTDISTINCTu1.emailFROMuser_tableu1INNERJOINuser_tableu2ONu1

php - 如何在 zend 框架中使 group by 可选?

我在zend中有一个fetchAll函数:publicfunctionfetchAll($where=1,$order=null,$limit=null,$group=null,array$fields=null){$where=(null==$where)?1:$where;$fields=(!isset($fields))?'*':$fields;$select=$this->db->select()->from("table",$fields)->where($where)->order($order)->group($group)->limit($limit,$offset);

mysql - 3 表加入 SUM 和 GROUP BY 不起作用

我正在使用三个表。AccountingLine-保存通用帐户详细信息预算-保存每个AccountingLine的预算数据(每个AccountingLine有很多行)实际-保存每个AccountingLine的实际成本数据(每个AccountingLine有很多行)我试图在单个查询中获取结果,该查询将从AccountingLine表返回所有行,并对Budget和Actuals表中每个AccountingLine的金额求和。使用下面的SQL,SUM不适用于预算或实际数据。如果我删除连接之一和SUM函数之一,那么它会为单个连接表正确计算。很奇怪...有人在MySQL的三个或更多表上使用多个S

mysql - 避免包含 group by 的嵌套子查询

有没有更好的方法在不使用嵌套子查询的情况下执行此查询?--selectallracesforjockeyswhichhavemultipleregionsselectdistinctr.id,r.descriptionfromjockeys_racesjrainnerjoinracesronr.id=jra.race_idwherejra.jockey_idin(selectjre.jockey_idfromjockeys_regionsjregroupbyjre.jockey_idhavingcount(*)>1);骑师可以属于多个地区。骑师可以参加多场比赛。

php - MySQL GROUP BY 多个列和字段

我试图在这里搜索答案,很少有问题与我的问题非常相似,但我仍然无法弄清楚如何在下面进行GROUPBY。MYSQL结构:ID|USERID|FRIENDID1|14|652|65|143|12|194|19|12如何使用php查询按ID1和ID2以及ID3和ID4进行分组?结果:1.14&652.12&19 最佳答案 SELECTLEAST(USERID,FRIENDID)asx,GREATEST(USERID,FRIENDID)asyFROMTableNameGROUPBYx,ySQLFIddleDemo

mysql - 是否有默认的 ORDER BY 值?

我有一个动态mysql查询,ORDERBY部分被硬编码到查询中。问题是,我不知道是否每个查询都会有一个ORDERBY,我也不知道哪些列可用于排序。有没有我可以写的默认值,这样我就可以使用了if(empty($order)){$order="default_value"}$query="select......ORDERBY$order" 最佳答案 查询结果没有默认顺序。如果您没有明确指定ORDERBY子句,则数据顺序未定义。您只能指定ASCDESC和一些列。 关于mysql-是否有默认的

PHP MySQL Group By结果数组

***********************id*typ*cl************************1*1*1**2*4*1**3*7*1**4*2*2**5*4*2**6*8*2***********************嗨,frnz,我对mysqlgroupby有问题......厌倦了在谷歌上寻找所以最后在这里发布......我的表结构如上所示。我正在使用以下查询...$sql2w=executeQuery("select*fromlogogroupbycl");while($line2=mysql_fetch_array($sql2)){echo$line2['ty

mysql - ORDER BY id 基于 IN 内的 id

如何根据IN中的idORDERBYidSELECT*FROMmallWHEREmall_idIN(3331083,33310110,3331080,33310107,33310119,3331410)ANDmall_status='1'LIMIT50结果应该是:3331083333101103331080.... 最佳答案 你需要FIELD功能:SELECT*FROMmallWHEREmall_idIN(3331083,33310110,3331080,33310107,33310119,3331410)ANDmall_status

mysql - 如何连接基于 GROUP BY 的记录?

这个问题在这里已经有了答案:CanIconcatenatemultipleMySQLrowsintoonefield?(16个答案)关闭8年前。我有一个结构如下的表:|id|textfield|text_group||1|yes|123||2|y|123||3|no|abc||4|n|abc|我想返回所有记录,但是我得到:|colA|text_group||yesy|123||non|abc|这是否可以简单地通过查询实现,或者我是否需要使用一些编程来格式化它?我本来可以做一个分组,但后来我丢失了结果ColA中的信息