MySQL5.7用group by分组根据组中某个字段的最大值求取那条记录(注意是整条记录)

时间:2024-04-07 07:42:29

首先注意,取每组最大的数据和取每组最大的一条记录是两个概念,前者很简单直接分组,max()即可。另外由于我的是5.7.24版本,5.7版本普遍存在一个问题,就是select的字段只能是group by后面出现的字段中的,不然报错,所以相应去掉的,若是Linux版的,可以参考https://blog.csdn.net/CSDN_ljm/article/details/83826879,Windows的自行查找解决办法。

思路:因为默认group by分组后取得是组内第一条记录,那么我们就将记录按某字段倒序排序,这样再分组,就会取出第一条也是组内最大的那条。

我首先通过连接拿到了想要的初始数据,我把这个表当做tmp。我想取surgery_part 组内score最大的那条记录

MySQL5.7用group by分组根据组中某个字段的最大值求取那条记录(注意是整条记录)

然后很自然的想到用select * from tmp order by score desc对其倒序排序

MySQL5.7用group by分组根据组中某个字段的最大值求取那条记录(注意是整条记录)

按照思路然后是把上面当做子查询即是select * from (select * from tmp order by score desc )group by surgery_part 

理论上取上图每组第一行,那么就应该取到标红的6那一行,然后发现

MySQL5.7用group by分组根据组中某个字段的最大值求取那条记录(注意是整条记录)

不是最大的6!!!

查看资料发现原来排序后必须加limit ,如果不加的话,数据不会先进行排序。所以

select * from (select * from tmp order by score desc  limit 10000)group by surgery_part 

MySQL5.7用group by分组根据组中某个字段的最大值求取那条记录(注意是整条记录)

好了,大功告成,另外再提供另外一种思路:子查询部分使用group by分组找到每组最大的,外层查询使用多字段的in查询。

SELECT *
FROM tmp WHERE (surgery_part,score) in

(
SELECT surgery_part,max(score)
FROM tmp
GROUP BY surgery_part
)