博客
关于我
MySQL中group by 与 order by 一起使用排序问题
阅读量:796 次
发布时间:2023-02-11

本文共 620 字,大约阅读时间需要 2 分钟。

MySQL中group by 与 order by 一起使用时,会先进行group by分组,然后对分组后的结果进行order by排序。这种情况下,group by的结果可能会影响最终的排序效果,因为它会优先取分组后的第一条记录进行排序。这在处理需要按某字段排序并取最大值的情况下,可能会导致意想不到的结果。

为了更好地解决这个问题,我们可以使用子查询的方法来优化查询逻辑。具体来说,可以先对奖励表进行排序,然后再进行分组和排序。这可以确保每个用户都能获得其最高奖励的记录,并且最终结果是按金额从大到小排序的。

以下是优化后的查询方法:

SELECT id, uid, money, datatimeFROM (    SELECT id, uid, money, datatime    FROM reward    ORDER BY money DESC) rGROUP BY r.uidORDER BY r.money DESC;

这样,外部查询会基于子查询返回的排序后的奖励记录进行分组和排序。每个分组的记录都是该用户的最高奖励记录,且最终结果是按金额从大到小排列的。

此外,如果不需要整条记录,可以使用max函数来获取每个用户的最高奖励金额,但这样只能获取金额信息,无法获取完整的奖励记录。因此,使用子查询方法更为合适。

通过以上方法,可以有效地解决group by和order by结合使用时的排序问题,确保查询结果符合预期。

转载地址:http://qsbfk.baihongyu.com/

你可能感兴趣的文章
Mysql工作笔记006---Mysql服务器磁盘爆满了_java.sql.SQLException: Error writing file ‘tmp/MYfXO41p‘
查看>>
mysql常用命令
查看>>
MySQL常用指令集
查看>>
MySQL底层概述—2.InnoDB磁盘结构
查看>>
MySQL底层概述—3.InnoDB线程模型
查看>>
MySQL底层概述—5.InnoDB参数优化
查看>>
MySQL底层概述—6.索引原理
查看>>
MySQL底层概述—7.优化原则及慢查询
查看>>
MySQL底层概述—8.JOIN排序索引优化
查看>>
MySQL底层概述—9.ACID与事务
查看>>
Mysql建立中英文全文索引(mysql5.7以上)
查看>>
MySQL开源工具推荐,有了它我卸了珍藏多年Nactive!
查看>>
Mysql当前列的值等于上一行的值累加前一列的值
查看>>
MySQL当查询的时候有多个结果,但需要返回一条的情况用GROUP_CONCAT拼接
查看>>
MySQL必知必会(组合Where子句,Not和In操作符)
查看>>
MySQL必知必会总结笔记
查看>>
MySQL快速入门
查看>>
MySQL快速入门——库的操作
查看>>
mysql快速复制一张表的内容,并添加新内容到另一张表中
查看>>
mysql快速查询表的结构和注释,字段等信息
查看>>