博客
关于我
MySQL中group by 与 order by 一起使用排序问题
阅读量:790 次
发布时间: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/

你可能感兴趣的文章
mt-datetime-picker type="date" 时间格式 bug
查看>>
myeclipse的新建severlet不见解决方法
查看>>
MyEclipse设置当前行背景颜色、选中单词前景色、背景色
查看>>
Mtab书签导航程序 LinkStore/getIcon SQL注入漏洞复现
查看>>
myeclipse配置springmvc教程
查看>>
MyEclipse配置SVN
查看>>
MTCNN 人脸检测
查看>>
MyEcplise中SpringBoot怎样定制启动banner?
查看>>
MyPython
查看>>
MTD技术介绍
查看>>
MySQL
查看>>
MySQL
查看>>
mysql
查看>>
MTK Android 如何获取系统权限
查看>>
MySQL - 4种基本索引、聚簇索引和非聚索引、索引失效情况、SQL 优化
查看>>
MySQL - ERROR 1406
查看>>
mysql - 视图
查看>>
MySQL - 解读MySQL事务与锁机制
查看>>
MTTR、MTBF、MTTF的大白话理解
查看>>
mt_rand
查看>>