mysql中row_number over功能实现

有时候我们想要获取每组的前n个记录,由于mysql中没有row_number() over 函数,之前部门大佬写了这个方法,觉得很实用,这里展示给大家。student表:s_id为学生id,s_name为学生姓名,s_birth为出生年月,s_sex为性别 score表:s_id 为学生id,c_id为课程id,s_score为对应的成绩。现想要取出每个...
mysql中row_number over功能实现
有时候我们想要获取每组的前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字段的,这是我们为了取数所构造的。2022-07-17
mengvlog 阅读 30 次 更新于 2025-09-09 18:00:56 我来答关注问题0
  •  翡希信息咨询 MySQL排序:rank|dense_rank|row_number的区别

    MySQL中的rank、dense_rank、row_number排序方式的区别如下:row_number:特点:展现连续性不重复排序。说明:为每一行分配一个唯一的序号,这个序号是根据指定的排序顺序连续增加的,不会有重复的序号。rank:特点:表现出跳跃式可重复排序。说明:为每一行分配一个排名,当存在相同值的行时,这些行会获得...

  • 本文旨在解析MySQL排序中的三种主要方式:rank、dense_rank、row_number,它们在处理数据排序时的差异。首先,让我们明确结论图的呈现:在排序效果上,row_number展现连续性不重复排序,rank则表现出跳跃式可重复排序,而dense_rank则为连续性可重复排序。对于具体的排序方式理解,我们可以从代码示例中获得直观...

  •  翡希信息咨询 Mysql实现SQL Row_Number函数,对数据进行分组排序

    使用变量进行分组排序:在MySQL中,可以通过用户定义的变量来模拟ROW_NUMBER函数的行为。首先,初始化一个变量,用于存储当前分组内的行号。然后,使用CASE WHEN语句和变量来判断当前记录是否与上一条记录属于同一分组。如果属于同一分组,则变量值加1;如果不同,则重置变量值为1。PARTITION BY:在MySQL中,...

  •  翡希信息咨询 mysql中在查询结果集中得到记录行号的方法

    可以使用MySQL的用户定义变量和自连接查询来生成行号。行号是根据查询结果的顺序生成的,查询结果变化时行号会随之改变。使用ROW_NUMBER函数:从MySQL 8.0开始支持。使用窗口函数ROW_NUMBER直接获取查询结果集中的行号。需要配合OVER子句来定义排序规则,例如按某个字段的升序或降序排列。使用MySQL内置变量:通过...

  •  张三讲法 mysql窗口函数rank() over、dense_rank() over、row_number() over 使用心得

    按各科成绩进行排序,并显示排名 rank()over()的使用 执行结果如下 rank()over()的使用,不使用partition by的效果 执行结果如下 row_number()over()的使用 执行结果如下 dense_rank()over()的使用 执行结果如下 与group by 共同使用 对学生总成绩进行从大到小排序 执行结果如下 ...

檬味博客在线解答立即免费咨询

mySQL相关话题

Copyright © 2023 WWW.MENGVLOG.COM - 檬味博客
返回顶部