SQL group by去重复且按照其他字段排序的操作
需求:
合并某一个字段的相同项,并且要按照另一个时间字段排序。
例子:
一开始用
selectcityfromtablegroupbycityorderbydatedesc
会报错因为date没有包含在聚合函数或GROUPBY子句中
然后用将date放入groupby中:
selectcityfromtablegroupbycity,dateorderbydatedesc
得到结果
但是得到的结果还是有重复的,没有解决
如果不按照时间排序,就会影响我之后的操作,所以百度了很久,终于找到了解决方法:
正确写法:
selectcityfromtablegroupbycityorderbymax(date)desc
发现很神奇的结果出来了
然后又找了一些资料,发现max()神奇的地方:
selectcity,max(date)asd1fromtablegroupbycity,d1orderbyd1desc
这里写在前面还能看到时间排序
如果还有更好的方法大家一起交流。
补充:MYSQL中去重,DISTINCT和GROUPBY的区别
例如有如下表user:
distinct会过滤掉它后面每个字段都重复的记录
用distinct来返回不重复的用户名:selectdistinctnamefromuser;,结果为:
用distinct来返回不重复的name和id:selectdistinctname,idfromuser;,结果为:
distinctname,id这样的写法,mysql会认为要过滤掉name和id两个字段都重复的记录。
如果sql这样写:
selectid,distinctnamefromuser
这样mysql会报错,因为distinct必须放在要查询字段的开头。
groupby则可以在要查询的多个字段中,针对其中一个字段去重:
selectid,namefromusergroupbyname;
以上为个人经验,希望能给大家一个参考,也希望大家多多支持毛票票。如有错误或未考虑完全的地方,望不吝赐教。
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。