mysql分组排序,取每组第一条数据

mysql分组排序,取每组第一条数据,第1张

MySQL:5.7

SQL语句的写法:

思路:先进行排序,然后再进行分组,获取每组的第一条。

derived_merge指的是一种查询优化技术,作用就是把派生表合并到外部的查询中,提高数据检索的效率。这个特性在MySQL5.7版本中被引入,可以通过如下SQL语句进行查看/开启/关闭等 *** 作。

上面虽然听起来感觉很牛逼的样子,但是实际情况是,这个新特性,不怎么受欢迎,容易引起错误。

假设我们现在把sql中的 distinct(a.id) tid ,去掉,会发现子查询(或者叫:临时表)中的order by a.id desc失效了。

为什么会这样呢?

原理分析:

我们这里使用了临时表排序,继而对其结果进行分组,结果显示失败,加了distinct(a.id) tid,后结果正确,原因是因为临时表(派生表derived table)中使用order by且使其生效,必须满足三个条件:

一旦外部表使用了group by, 那么临时表(派生表 derived table)将不会执行filesort *** 作(即 order by 会被忽略 )。之后我使用了limit可以使其生效,原因是因为要使派生表order by生效, 派生表可以通过使用group by、limit、having、distinct等等使其生效 (方法有好多,详情可看文档 https://dev.mysql.com/doc/refman/5.7/en/derived-table-optimization.html )

原文链接:

https://blog.csdn.net/u013066244/article/details/116461584

有时候我们需要更新table中分组排序后的第一条数据。比如:给各学科分数第一名的学生打标。

如上图所示,现在有一张学生成绩表,我想要各科第一名的学生打标,也就是向mark字段中写入“第一名”标记。那么预想得到的效果应该是这样的:

由于需要使用到group by , 所以需要先检查下mysql对应的sql_mode 是否包含 ONLY_FULL_GROUP_BY ,如果包含,则将sql_mode中的ONLY_FULL_GROUP_BY移除掉,否则下面的SQL可能执行不成功

上面sql中t0表为什么需要使用到DISTINCT,可以查看文章:

执行结果:

SQL分析:

上面的SQL感觉还是过于复杂了,看过下面的文章后:

可以将上面的SQL优化优化.....

优化版写法:

执行结果:

SQL分析:

执行结果:

SQL分析:

上面的SQL中使用到了窗口函数,关于窗口函数相关文章:


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/6129108.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-03-15
下一篇 2023-03-15

发表评论

登录后才能评论

评论列表(0条)

保存