草庐IT

clientlibs-explained-by-example

全部标签

sql - mysql 获取 order by 发生在 group by 之前

我有三个表,这里只显示相关的列Table:groupsColumns:group_id,name.Table:groups_to_messageColumns:group_id,message_idTable:messagesColumns:message_id,created(date)我基本上需要找到每个组的最后一条消息,而不显示重复的组。我试过像这样使用分组方式:SELECTm.created,g.group_idFROMgroupssasgJOINgroup_to_messageasgmON(g.group_id=gm.group_id)JOINmessagesasmGROUP

MySQL GROUP BY NULL 和 EMPTY

在MySQL查询中,我正在使用文本字段执行GROUPBY。由于原始数据的性质,某些行包含此字段的空字符串,而其他行为truenull。分组时,如何将空字符串和null分组在一起,将两者都视为null? 最佳答案 这可以通过SELECTCASE来完成。可能有一种我不知道的更简单的方法。SELECTCASE的格式是SELECTCASEWHENtable_name.text_fieldISNULLORtable_name.text_field=''THENnullELSEtable.text_fieldENDasnew_field_nam

mysql - 更新列 Group by 的 SUM

UPDATEtable_nameSETcol3=SUM(col2)GROUPBYcol1报错:YouhaveanerrorinyourSQLsyntax;checkthemanualthatcorrespondstoyourMySQLserverversionfortherightsyntaxtousenear'GROUPBYcol1'如何解决?Col1|col2|col3Water|22|water|3|water|5|Air|10|Earth|3|Air|5|Iwantincol3theresultsasfollowsCol1|col2|col3Water|22|30water|3

MySQL SELECT 列 COUNT(name) WHERE 条件 GROUP BY 列?

嘿,这是我正在使用的SQL语句$sql="SELECTnumber,COUNT(name)FROMpeopleWHEREid='$id'GROUPBYnumber";$result=mysql_query($sql);while($row=mysql_fetch_array($result)){$statarray['stat'.$i]=$row['COUNT(name)'];$i++;}数字列针对每个名称存储0、1、2或3,因此数组返回总计每个数字有多少名称。这工作正常。唯一的问题是,如果所有的名字都存储了一个数字1,我的数组条目“stat0”不会告诉我有多少个0,因为它被1的数量所

php - MySQL GROUP BY 和填充空行

我确定之前已经回答过这个问题,但我找不到我需要的详细信息。对于分析系统,我需要能够对行进行分组并将它们返回到图表上,按分钟、小时、天、月或年分组。我可以正常工作(下面的示例代码)。SELECTCOUNT(DISTINCTuser_id),`hour`,`timestamp`FROMtracking_requestWHEREsite_id='3'AND`timestamp`'2011-08-2922:00:00'GROUPBY`hour`,`day`,`month`,`year`ORDERBY`timestamp`ASC问题是,像大多数图表一样,我需要填补没有数据的空白(例如,最后3分钟

MySQL ORDER BY 列 ASC 包含两个未正确按字母顺序排列的单词

我正在尝试对下表进行排序:表:人物+---+----------------------+|id|Ethnicity|+---+----------------------+|1|'Hispanic'||2|'AsianAmerican'||3|'White'||4|'AfricanAmerican'||5|'AmericanIndian'||6|'Other'|+---+----------------------+SQL查询SELECTDISTINCTEthnicityFROMPeopleORDERBYEthnicityASC结果这会产生:+--------------------

mysql - 在使用 order by with limit 时避免在 mysql 中进行全表扫描

我正在写一个查询:select*fromtable_nameorderbyidlimit21在我使用限制小于或等于20之前,扫描的行等于确切的获取行(例如,如果限制为10,则扫描的行也只有10)。如果限制超过20,则表将被完全扫描。唯一为主键id创建的索引。谁能说出这种情况下全表扫描的原因?我的表有1099行。ExplainResult:---------------------------------------------------------------------------id|selecttype|table|type|possiblekeys|keys|key_len|

mysql - 如何仅在 WHERE COUNT(使用 GROUP BY 的子查询)=1 时更新值?

当它是组中唯一的行时,我试图通过单个查询将行值设置为1。当前表(CATEGORY_BRAND):|categoryId|brandId|featured||-----------+---------+----------||1|100|-1||1|101|-1||1|102|-1||2|100|-1||3|110|-1||3|111|-1||4|102|-1||5|101|-1||6|100|-1||6|110|-1||...|...|...|希望的结果(CATEGORY_BRAND):|categoryId|brandId|featured||-----------+--------

php - MYSQL SELECT SUM() BY DATE IF NO MATCH RETURN 0

我已经将三个表相互连接起来。我正在查询关键字+统计信息。我需要按日期范围获取数据,并且如果没有该特定日期范围内的数据我希望它返回0个统计信息假设我的查询是:SELECTkeyword,SUM(stat)FROMkeywordsWHEREdate>='2012-07-10'GROUPBYkeyword;它会返回|我的关键词1|3||我的关键词2|6|示例表格内容:|编号|关键字|统计|日期|关键字组||1|我的关键字1|2|2012-07-11|1||2|我的关键字1|1|2012-07-12|1||3|我的关键字2|6|2012-07-11|1||4|我的关键字3|10|2012-07

Mysql 查询优化、EXPLAIN 和执行缓慢

一些查询存在一些实际问题,尤其是这个问题。信息如下。tgmp_games,大约20k行CREATETABLEIFNOTEXISTS`tgmp_games`(`g_id`int(8)NOTNULLAUTO_INCREMENT,`site_id`int(6)NOTNULL,`g_name`varchar(255)NOTNULL,`g_link`varchar(255)NOTNULL,`g_url`varchar(255)NOTNULL,`g_platforms`varchar(128)NOTNULL,`g_added`datetimeNOTNULL,`g_cover`varchar(255