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

本文介绍了在MySQL5.7中,如何根据分组中的最大值获取对应的完整记录。方法一是通过先排序后分组,需要注意需要添加`LIMIT`来确保数据先排序;方法二是使用子查询结合`GROUP BY`和`IN`操作。此外,还提到了5.7版本的一个限制,即`SELECT`字段必须出现在`GROUP BY`后的字段中,以及解决这个问题的方法。
摘要由CSDN通过智能技术生成

首先注意,取每组最大的数据和取每组最大的一条记录是两个概念,前者很简单直接分组,max()即可。另外由于我的是5.7.24版本,5.7版本普遍存在一个问题,就是select的字段只能是group by后面出现的字段中的,不然报错,若想去掉这个限制Linux版的,可以参考https://blog.csdn.net/CSDN_ljm/article/details/83826879,Windows的自行查找解决办法。如果自己没有管理员的权限,无法修改,则用方法二多字段in查询解决

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

方法一:

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

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

按照思路然后是

评论 11
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值