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()

相关推荐
TE-茶叶蛋11 分钟前
Redis 原子操作
数据库·redis·缓存
Linux运维老纪14 分钟前
Python文件操作及数据库交互(Python File Manipulation and Database Interaction)
linux·服务器·数据库·python·云计算·运维开发
Bruce_Liuxiaowei20 分钟前
MCP Python SDK构建的**SQLite浏览器**的完整操作指南
数据库·python·sqlite
数据与人工智能律师33 分钟前
正确应对监管部门的数据安全审查
大数据·网络·数据库·人工智能·区块链
瓯雅爱分享35 分钟前
任务管理系统,Java+Vue,含源码与文档,科学规划任务节点,全程督办保障项目落地提效
java·mysql·vue·软件工程·源代码管理
2401_8979300639 分钟前
什么是非关系型数据库
数据库·oracle
鱼丸丶粗面1 小时前
Python 读取 txt 文件详解 with ... open()
linux·数据库·python
拾荒者.1261 小时前
设计一个关键字统计程序:利用HashMap存储关键字统计信息,对用户输入的关键字进行个数统计。
数据库·python·mysql
encoding-console1 小时前
欧拉环境(openEuler 22.03 LTS SP3)安装移动磐维数据库(PanWeiDB_V2.0-S2.0.2_B01)步骤
数据库·虚拟机·欧拉·磐维数据库
辰哥单片机设计1 小时前
PTC加热片详解(STM32)
数据库·mongodb