首页 > 数据库 > mysql教程 > MySQL中rank() over、dense_rank() over和row_number() over怎么用

MySQL中rank() over、dense_rank() over和row_number() over怎么用

PHPz
发布: 2023-05-26 19:55:29
转载
1614 人浏览过

MySQL中rank() over、dense_rank() over和row_number() over怎么用

上述的这道题,如果不使用本次用到的函数的答案如下,也就是说,如果你的MySQL无法使用本篇中的函数,可以通过下面的语法逻辑做替换。

SELECT t1.Score as Score, ( SELECT COUNT(DISTINCT t2.Score) FROM Scores t2 WHERE t2.Score >= t1.Score ) AS `Rank` 
FROM Scores t1 ORDER BY t1.Score DESC
登录后复制

rank() over(业务逻辑)

作用:查出指定条件后的进行排名,条件相同排名相同,排名间断不连续。

这个函数可用于学生排名,其中成绩相同的两个学生会被并列,下一名学生将腾出其应有的名次。即:1 1 3 4 5 5 7

SELECT id, name, score, rank() over(ORDER BY score DESC) AS 'rank' FROM student
登录后复制

MySQL中rank() over、dense_rank() over和row_number() over怎么用

dense_rank() over(业务逻辑)

作用:查出指定条件后的进行排名,条件相同排名相同,排名间断不连续。

说明:和rank() over 的作用相同,区别在于dense_rank() over 排名是密集连续的。使用此函数来确定学生的排名。当出现成绩相同的情况时,两名学生将并列该排名,排名的下一位将根据接下来的名次进行确定。即:1 1 2 3 4 5 5 6

SELECT id, name, score, dense_rank() over(ORDER BY score DESC) AS 'rank' FROM student
登录后复制

MySQL中rank() over、dense_rank() over和row_number() over怎么用

row_number() over(业务逻辑)

作用:查出指定条件后的进行排名,条件相同排名也不相同,排名间断不连续。

即使查询出的数值相同,这个函数会进行连续排序,不需要考虑是否并列。即:1 2 3 4 5 6

SELECT id, name, score, row_number() over(ORDER BY score DESC) AS 'rank' FROM student
登录后复制

MySQL中rank() over、dense_rank() over和row_number() over怎么用

后记

函数中的业务逻辑可以是复杂的,不局限于 ORDER BY,也可以加 PARTITION BY。

### 分班级排名
SELECT id, name, score, class, row_number() over(PARTITION BY class ORDER BY score DESC) AS 'rank' 
FROM student
登录后复制

MySQL中rank() over、dense_rank() over和row_number() over怎么用

以上是MySQL中rank() over、dense_rank() over和row_number() over怎么用的详细内容。更多信息请关注PHP中文网其他相关文章!

相关标签:
来源:yisu.com
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板