草庐IT

mooncatventures-group

全部标签

mysql - 在 MySQL 查询中,DISTINCT 是在 GROUP BY 之前还是之后应用的?

下面是我正在运行的查询。DISTINCT是在GROUPBY之前还是之后应用?表格如下所示:id,stateid不是唯一的,一个实体可以有多个状态相同或不同的条目。这种行为可能会彻底改变我的结果。如果在GROUPBY之前应用DISTINCT,那么在整个集合中它只会对每个entity计数一次(只会出现在一个状态)。如果它发生在之后,那么每个实体在每个状态中只会被计算一次,但可以在多个状态中被计算。SELECTstate,COUNT(DISTINCTentity_id)AScountFROMentitiesGROUPBYstateORDERBYcountDESC;我的目标是在每个state中

mysql - 在三个不同的列上使用 MAX、WHERE 和 GROUP BY 提高 SQL 查询的速度

我正在尝试加快在约2000万行的表上完成大约需要60秒的查询。对于这个例子,表格有三列(id、dateAdded、name)。id是主键。我添加到表中的索引是:(dateAdded)(name)(id,name)(id,name,dateAdded)我尝试运行的查询是:SELECTMAX(id)asid,nameFROMexampletableWHEREdateAdded日期因查询而异。这样做的目的是在添加日期或之前获取每个名称的最新条目。当我在查询中使用explain时,它告诉我它正在使用(id,name,dateAdded)索引。+----+-------------+------

sql - MySQL - Where IN 与 GROUP_CONCAT 一起

IN()中使用的查询返回:1,2。然而,整个查询返回0行,这是不可能的,因为它们存在。我在这里做错了什么?SELECTDISTINCTli.auto_idFROMlinksASliJOINgroup_dataASgiONli.auto_id=gi.autoidANDli.user_id=gi.useridWHEREgi.groupidIN(SELECTCAST(GROUP_CONCAT(gf.groupid)ASCHAR)FROMgroup_followersASgfWHEREgf.userid_ext='1'GROUPBYgf.userid_ext)ANDli.keywordLIKE

SQL 条件 GROUP BY : how to do it?

假设我有以下SQL查询:SELECTMeeting.idASmeetingId,Bill.idASbillIdFROMMeetingLEFTJOINBillONMeeting.FK_BillId=Bill.id输出如下:meetingId|billId------------------a|NULLb|NULLc|1d|1e|1f|2g|2我想要以下输出,按非NULL的billId分组:meetingId|billId------------------a|NULLb|NULLc|1f|2我怎样才能做到这一点?顺便说一句,我不关心分组结果的模棱两可的meetingId。感谢您的帮助!

mysql - 使用 "group by ... with rollup"时区分NULL

当我使用groupby...withrollup运行查询时:selecta,b,sum(c)fromgroupbya,bwithrollup;我在(我认为是)查询的PK(即分组依据列)中得到重复行:+------+------+--------+|a|b|sum(c)|+------+------+--------+|NULL|NULL|13||NULL|1|4||NULL|3|8||NULL|4|9||NULL|NULL|34||1|3|17||1|4|NULL||1|17|2||1|NULL|19||2|NULL|6||2|1|17||2|3|17||2|NULL|40||4|17

mysql GROUP BY 子句验证

假设我有一个包含以下内容的表格:mysql>select*fromtest;+----+------+|id|val|+----+------+|1|1||2|1||3|1||4|1||5|2||6|2||7|2||8|2|+----+------+8rowsinset(0.00sec)mysql>现在我使用groupby子句运行错误的SQL查询并且没有对id列进行任何聚合并得到错误的结果:mysql>selectid,valfromtestgroupbyval;+----+------+|id|val|+----+------+|1|1||5|2|+----+------+2rows

Mysql用group by更新最大值

我有一个已经有很多行的简单表格:idgrade...11...22...32...41...51...现在我想添加一列“relative_order”,这是在那个年级的顺序。所以表格变成:idgrade...relative_order11...122...132...241...251...3添加列后,所有的relative_order首先变为0。如何使用update语法填充relative_order列?我尝试使用内部联接,但失败了:UPDATEtableASiINNERJOIN(SELECTmax(relative_order)asmOrder,gradeFROMtableGRO

mysql - 在 IN 子句中使用 GROUP_CONCAT 结果 Mysql

我有一个返回逗号分隔整数的查询喜欢:selectGROUP_CONCAT(ids)fromtable2现在我想在另一个查询中使用该结果喜欢:select*fromtable1wherecolumnin(selectGROUP_CONCAT(ids)fromtable2)在这种情况下,它只会考虑IN子句中的第一个值。 最佳答案 我同意@Alma的观点,这不能用IN来完成,你可以用FIND_IN_SET来完成。,但如果你能用IN做到这一点,那可能是更好的方法:SELECT*FROMtable1WHEREfind_in_set(ids,(

sql - MySQL JOIN/GROUP_CONCAT 第二张表?

所以我有一个完美的查询:SELECTusers.*,GROUP_CONCAT(categories.category_name)AScategoriesFROMusersLEFTOUTERJOINuser_categoriesONusers.user_id=user_categories.user_idLEFTOUTERJOINcategoriesONuser_categories.category_id=categories.category_idWHEREusers.user_city='brooklyn'GROUPBYusers.user_idLIMIT10;假设我有另一个包含电

MySQL:是否可以 group_concat 多行?

这是我想要的:attribute_nameattribute_idattribute_value--------------------------------------------------------------------Appliances16,17,18,19Washer,Dryer,Dishwasher,MicrowaveConsoles7,3PS3,XBox这接近于我所拥有的:attribute_nameattribute_idattribute_value-------------------------------------------------Applian