当前位置:首页 > MySQL > 正文内容

解决MySQL子查询排序失效的问题

canca5年前 (2020-09-28)MySQL1056

问题描述:高版本的MySQL(5.6以上)在子查询中使用order by 语句后查询结果并不会显示排序后的结果。
以下是我使用的两个解决方法,供参考:
1.当子查询的order by语句后面没有limit关键字时,数据库会自动优化,即忽略order by语句。因此只需要添加limit关键字即可。
2.在子查询中使用聚合函数。


具体示例如下所示: 现在我有一张表message,存放用户的对话信息,表中内容如下所示(图中我的一些测试数据请忽略:))

message表

现在我想查询按照conversation_id分组后,每组的created_date值最大的数据项所组成的所有数据结果。查询结果的实际意义就是每组对话中最新的一条对话信息。预期查询结果应该显示id为2和10所在的两条数据。

先直接在子查询中使用order by语句,查询语句为:
select * from (select * from message order by created_date desc) b group by conversation_id;
查询结果为:

查询结果

可以发现查询的结果与预期刚好相反,数据库默认查询每组created_date值最小的那一个,即最老的一个对话信息。

**1.**使用方法1解决:
查询语句:
select * from (select * from message order by created_date desc limit 9999) b group by conversation_id;
子查询中增加了限制查询9999条的语句,这样数据库就不会自动优化order by语句,但是要保证限制的数据要大于操作的数据的总数量。
查询结果:

此时查询结果与预期相同。

**2.**使用方法2解决:
select * from message ,
( select max(created_date) as date from message group by conversation_id) b
where b.date = message.created_date order by created_date desc;
在子查询中先使用聚合函数max找到每组created_date的最大值,然后通过where后的语句获取message中max(created_date)所在的数据项,最后再通过时间由大到小倒序排序即可。

查询结果:(下图截错了,仅展示的是没有对查询结果进行倒序排序的结果)
查询结果

花了一下午回顾了一下数据库书,想到了第二个方法,同时也发现好多新大陆。充分说明之前学的太不扎实了,靠死记了一些,不用了之后就基本全忘了。还是自己动手能力差了些,不会学以致用。现在在努力。

扫描二维码推送至手机访问。

版权声明:本文由Ant.Master's Blog发布,如需转载请注明出处。

本文链接:https://iant.work/post/729.html

标签: MySQL
分享给朋友:

“解决MySQL子查询排序失效的问题” 的相关文章

mysql 配置命令大全

--auto-rehash       Enable automatic rehashing. One doesn't need to use             ...

mysql 外鍵約束

1. 什么是参照完整性?——————–参照完整性(完整性约束)是数据库设计中的一个重要概念,当数据库中的一个表与一个或多个表进行关联时都会涉及到参照完整性。比如下面这个例子:文章分类表 -  categoriescategory_id     nam...

MySQL备份与恢复语句

mysql备份语句:E:\MySQL Server 5.0\bin>mysqldump -uroot -padmin --default-character-set=utf8 --opt --extended-insert=false --triggers -R --hex-blob -x s...

Mysql 删除重复记录

1、 具体实现如下: Table Create Table ------------ -------------------------------------------------------- users_groups CREATE TABLE `users_groups` ( `id`...

MySQL数据库备份与还原

MySQL数据库备份与还原

       平时工作中常常会遇到数据库备份、还原等场景,但有些服务器上不允许装前台工具,只好用命令行来操作。并且更重要的一点是:如果数据量比较大的话,借助工具来操作会非常卡,而使用命令行则无压力。应用场景不同,有时候需要对整个库进行操作,有时候则只需要对若干...

MySQL性能优化的最佳20+条经验

MySQL性能优化的最佳20+条经验

今天,数据库的操作越来越成为整个应用的性能瓶颈了,这点对于Web应用尤其明显。关于数据库的性能,这并不只是DBA才需要担心的事,而这更是我 们程序员需要去关注的事情。当我们去设计数据库表结构,对操作数据库时(尤其是查表时的SQL语句),我们都需要注意数据操作的性能。这里,我们不会讲过 多的SQL语句...

发表评论

访客

◎欢迎参与讨论,请在这里发表您的看法和观点。