Mysql5.7版本中,查询分组GROUP BY通过子查询中ORDER BY进行排序无效的问题解决办法

文章目录

一、场景:

问题描述:Mysql5.7版本中,查询分组GROUP BY通过子查询中ORDER BY进行排序无效的问题解决办法。

应用场景:一对多的关系,通常需要取最新、最近的一条数据时。

举例:比如客户表,订单表,一个客户可能有很多订单,一对多的关系,我们想查询每个客户最新的一单数据

客户id 姓名
1001 客户张三
1002 客户李四
订单id 客户id 下单时间
1 1001 2023-11-10 15:20:00
2 1001 2023-11-11 15:10:00
3 1002 2023-09-11 12:20:00
4 1003 2023-10-11 14:20:00
5 1003 2023-12-11 20:20:00
6 1003 2023-12-21 14:20:00

常规操作:尝试使用子查询,先排序再分组,取最新一条

java 复制代码
SELECT * FROM ( SELECT  *  FROM `order_info` ORDER  BY created_time desc ) AS t GROUP  BY customer_id 

但是这个方式在低版本中有效,

在 5.7 版本中引入新特性 derived_merge 优化过后,group by子句中使用order by导致order by失效,所以你发现取到的不是最新的!

二、解决办法

1、使用 having 来阻止合并

java 复制代码
SELECT * FROM ( SELECT  *  FROM `order_info` HAVING  1=1  ORDER  BY created_time desc ) AS t GROUP  BY customer_id 

2、足够大的limit

用一个超级大的limit放在order by后面

java 复制代码
SELECT * FROM ( SELECT  *  FROM `order_info` ORDER  BY created_time desc   LIMIT 1000000 ) AS t GROUP  BY customer_id 

3、子查询

一些场景,如果是有序递增的,可以通过取Max(id)方式,实现效果

java 复制代码
SELECT * FROM  order_info where order_id in ( SELECT MAX( order_id ) FROM order_info GROUP  BY customer_id )

取到最新的数据在关联客户表查询即可。

上边提到了取最新、最近数据的可试方法,那还有一种常见场景是删除重复的记录(只保留一条)怎么处理呢:SQL删除重复的记录(只保留一条)-窗口函数row_number()

相关推荐
csdn_aspnet17 小时前
用 MySQL 玩转数据可视化:从底层数据到 BI 工具的桥接
数据库·mysql·信息可视化·bi
wb0430720117 小时前
一次jvm配置问题导致的数据库连接异常
服务器·jvm·数据库·后端
酷酷的崽79817 小时前
搭载cpolar,让PostgreSQL数据库远程访问超丝滑
数据库·postgresql
API开发17 小时前
apiSQL 迁移至已有 PostgreSQL 数据库指南
数据库·postgresql·api开发·postgrest·接口开发工具·api管理软件
学掌门17 小时前
从数据库到可视化性能,5个大数据分析工具测评,python只排倒数
数据库·python·数据分析
编程小风筝17 小时前
Django REST framework实现安全鉴权机制
数据库·安全·django
secondyoung17 小时前
队列原理与实现全解析
c语言·数据库·mysql·算法·队列
05大叔18 小时前
微服务Day01 MP
数据库·oracle
Jan123.18 小时前
深入理解数据库事务与锁机制:InnoDB实战指南
数据库·学习
wWYy.18 小时前
详解redis(6):数据结构string、list
数据库·redis·缓存