mysql5.1.39_mysql5.7.10和mysql5.5.39两个版本对于group by函数的处理差异

原理还是没有搞清楚,在官网上看了一下,看的不是很清楚。一并都记录一下。

问题描述:

存在如下数据结构

fa347baf6f6f99c9f881497099ec5486.png

sql:

求用户最近更新的那条记录

思路:

按照modify_time排序后按照user_id分组。

sql如下:

SELECT

*

FROM

(

SELECT

id,

doc_ass_modify_time,

user_id

FROM

health_report_assessment hra

ORDER BY

doc_ass_modify_time DESC

) reportTemp

GROUP BY

req_user_id

改sql在 mysql5.5.39 查询结果为:

6177ea937de7ed059a59d2cfc58bab84.png

修改后的sql

SELECT

*

FROM

(

SELECT

DISTINCT id,

doc_ass_modify_time,

user_id

FROM

health_report_assessment hra

ORDER BY

doc_ass_modify_time DESC

) reportTemp

GROUP BY

req_user_id

子查询中增加了distinct的关键字。

在两个版本中,查询均取到最新的数据。

在官网查到的资料

921ca26078fede94bba6e0a1c83e4e38.png

大体了解他的意思,但也没有看出来和group by 有多大的关系。

http://dev.mysql.com/doc/refman/5.7/en/group-by-handling.html

先记录一下,欢迎拍砖。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值