MySQL 分组选出某值最大的一行数据(需要加 limit)

MySQL 分组选出某值最大的一行数据(需要加 limit),第1张

在mysql中使用group by进行分组后取某一列的最大,我们可以直接使用MAX()函数来实现,但是如果我们要取最大值对应的ID

那么我们需要取得整行的数据该怎么办?

起初搜寻到的资料是这样的:

首先按照 create_time 倒叙排序,然后分组,那么每个分组中排在最上面的记录就是时间最大的记录

但是结果不是这样的,经过搜集资料,得出需要在排序后边加 limit 10000000000

如果不加的话,数据不会先进行排序,通过 explain 查看执行计划,可以看到没有 limit 的时候,少了一个 DERIVED *** 作。

如截图,查询占line_id最多的stop

1、常规思路如下,这样只能查出指定的1条、2条最大记录,满足不了同时存在多个最大值的情况

2、继续思考,通过先取得最大值 条件判断查出所有最大值数据

3、语句太长,如何优化?效率更高


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/7168969.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-02
下一篇 2023-04-02

发表评论

登录后才能评论

评论列表(0条)

保存