mysql窗口函数rank() over、dense_rank() over、row_number() over 使用心得

mysql窗口函数rank() over、dense_rank() over、row_number() over 使用心得,第1张

一枚小产品的学习记录

在做sql练习题时了解到的新函数,做个简要的记录,若有不严谨的地方,请指正。

mysql 8.0以上版本才支持窗口函数

以下是个人总结

另外:over(partition by字段1 order by 字段2)中的partition by 字段1 是可以省略的但是order by 字段2 不可省略

详细演示见下文:

本文内使用到的建表、插入数据sql 可在我写的sql面试50题的第一篇文章内找到.

按各科成绩进行排序,并显示排名

#rank()over()的使用

#执行结果如下

#rank()over()的使用,不使用partition by的效果

#执行结果如下

#row_number()over()的使用

#执行结果如下

#dense_rank()over()的使用

#执行结果如下

#****与group by 共同使用

#对学生总成绩进行从大到小排序

#执行结果如下

有时候我们想要获取每组的前n个记录,由于mysql中没有row_number() over 函数,之前部门大佬写了这个方法,觉得很实用,这里展示给大家。

student表:

s_id为学生id,s_name为学生姓名,s_birth为出生年月,s_sex为性别

score表:

s_id 为学生id,c_id为课程id,s_score为对应的成绩。

现想要取出每个课程前3名的学生信息、课程id,成绩与对应课程内排名,如下所示:

+------+--------+------------+-------+------+---------+------+

| s_id | s_name | s_birth| s_sex | c_id | s_score | rank |

+------+--------+------------+-------+------+---------+------+

| 01 | 赵雷 | 1990-01-01 | 男| 01 | 80 |1 |

| 03 | 孙风 | 1990-05-20 | 男| 01 | 80 |2 |

| 05 | 周梅 | 1991-12-01 | 女| 01 | 76 |3 |

| 01 | 赵雷 | 1990-01-01 | 男| 02 | 90 |1 |

| 07 | 郑竹 | 1989-07-01 | 女| 02 | 89 |2 |

| 05 | 周梅 | 1991-12-01 | 女| 02 | 87 |3 |

| 01 | 赵雷 | 1990-01-01 | 男| 03 | 99 |1 |

| 07 | 郑竹 | 1989-07-01 | 女| 03 | 98 |2 |

| 02 | 钱电 | 1990-12-21 | 男| 03 | 80 |3 |

+------+--------+------------+-------+------+---------+------+

查询实现如下:

首先看表b的部分,令@current_id=c_id,当c_id不是当前的课程时,rank重新从1开始计数,某则在在当前rank上加1。

需要注意的是,此时的排序需要现基于课程id,再基于成绩逆序。

在此基础上基于s_id连接student表即可,另外在最后的条件设定中需要用having不能用where,因为在原表中是不存在rank字段的,这是我们为了取数所构造的。

我们在学习MYSQL时,最让我们头疼的一个问题是:如何实现分组排序。我们都知道MYSQL没有一个专门的函数。让我们一起来探索,如何实现分组排序呢?

第一:设置变量并赋值时,符号是 :=

第二:一定要进行排序order by ,否则会出现这样的情况:


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

原文地址:https://54852.com/zaji/7675444.html

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

发表评论

登录后才能评论

评论列表(0条)

    保存