【随手记】MySQL中ROW_NUMBER()、RANK()和DENSE_RANK()函数的用法

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,高可用系列 2核4GB
简介: 【随手记】MySQL中ROW_NUMBER()、RANK()和DENSE_RANK()函数的用法

当使用ROW_NUMBER()函数、RANK()函数和DENSE_RANK()函数对一列数进行排名时,它们的用法和结果会有一些区别。

假设有一个名为students的表,包含学生的姓名和分数信息。

+----+-------+--------+
| ID | Name  | Score  |
+----+-------+--------+
| 1  | Alice | 80     |
| 2  | Bob   | 85     |
| 3  | Cathy | 90     |
| 4  | David | 90     |
| 5  | Emma  | 95     |
+----+-------+--------+
  1. 使用ROW_NUMBER()函数进行排名:
SELECT Name, Score, ROW_NUMBER() OVER (ORDER BY Score DESC) AS RowNumber
FROM students;

结果如下:

+-------+--------+-----------+
| Name  | Score  | RowNumber |
+-------+--------+-----------+
| Emma  | 95     | 1         |
| Cathy | 90     | 2         |
| David | 90     | 3         |
| Bob   | 85     | 4         |
| Alice | 80     | 5         |
+-------+--------+-----------+

ROW_NUMBER()函数会为每一行分配一个唯一的数字,按照分数降序排名。注意,分数相同的行会有不同的排名。

  1. 使用RANK()函数进行排名:
SELECT Name, Score, RANK() OVER (ORDER BY Score DESC) AS Rank
FROM students;

结果如下:

+-------+--------+------+
| Name  | Score  | Rank |
+-------+--------+------+
| Emma  | 95     | 1    |
| Cathy | 90     | 2    |
| David | 90     | 2    |
| Bob   | 85     | 4    |
| Alice | 80     | 5    |
+-------+--------+------+

RANK()函数会为相同分数的行分配相同的排名,然后跳过下一个排名。在上面的例子中,Cathy和David的分数相同,所以它们都被分配了排名2。

  1. 使用DENSE_RANK()函数进行排名:
SELECT Name, Score, DENSE_RANK() OVER (ORDER BY Score DESC) AS DenseRank
FROM students;

结果如下:

+-------+--------+-----------+
| Name  | Score  | DenseRank |
+-------+--------+-----------+
| Emma  | 95     | 1         |
| Cathy | 90     | 2         |
| David | 90     | 2         |
| Bob   | 85     | 3         |
| Alice | 80     | 4         |
+-------+--------+-----------+

DENSE_RANK()函数会为相同分数的行分配相同的排名,并连续计数下去。在上面的例子中,Cathy和David的分数相同,它们都被分配了排名2,并且没有排名3。排名4则对应的是分数为90的Linda。该函数的作用是按照指定的列的值对行进行排序,并为相同值的行分配相同的排名,连续计数下去。

相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
30天前
|
JSON 关系型数据库 MySQL
Mysql(5)—函数
MySQL提供了许多内置的函数以帮助用户进行数据操作和分析。这些函数可以分为几类,包括聚合函数、字符串函数、数值函数、日期和时间函数、控制流函数等。
70 1
Mysql(5)—函数
|
11天前
|
关系型数据库 MySQL Serverless
MySQL函数
最常用的MySQL函数,包括聚合函数,字符串函数,日期时间函数,控制流函数等
|
15天前
|
SQL NoSQL 关系型数据库
|
26天前
|
关系型数据库 MySQL 数据库
mysql中tonumber函数使用要注意什么
在处理这类转换操作时,考虑周全,利用提供的高性能云服务器资源,可以进一步提升数据库处理效率,确保数据操作的稳定性和安全性,尤其是在处理大量数据转换和运算密集型应用时。
79 0
|
29天前
|
关系型数据库 MySQL 数据处理
企业级应用 mysql 日期函数变量,干货已整理
本文详细介绍了如何在MySQL8.0中使用DATE_FORMAT函数进行日期格式的转换,包括当日、昨日及不同时间段的数据获取,并提供了实际的ETL应用场景和注意事项,有助于提升数据处理的灵活性和一致性。
39 0
|
算法
Leetcode 313. Super Ugly Number
题目翻译成中文是『超级丑数』,啥叫丑数?丑数就是素因子只有2,3,5的数,7 14 21不是丑数,因为他们都有7这个素数。 这里的超级丑数只是对丑数的一个扩展,超级丑数的素因子不再仅限于2 3 5,而是由题目给定一个素数数组。与朴素丑数算法相比,只是将素因子变了而已,解法还是和朴素丑数一致的。
99 1
|
5月前
|
存储 SQL 算法
LeetCode 题目 65:有效数字(Valid Number)【python】
LeetCode 题目 65:有效数字(Valid Number)【python】
|
6月前
|
存储 算法
【LeetCode力扣】单调栈解决Next Greater Number(下一个更大值)问题
【LeetCode力扣】单调栈解决Next Greater Number(下一个更大值)问题
44 0
|
存储
Leetcode Single Number II (面试题推荐)
给你一个整数数组,每个元素出现了三次,但只有一个元素出现了一次,让你找出这个数,要求线性的时间复杂度,不使用额外空间。
39 0
|
算法
LeetCode 414. Third Maximum Number
给定一个非空数组,返回此数组中第三大的数。如果不存在,则返回数组中最大的数。要求算法时间复杂度必须是O(n)。
94 0
LeetCode 414. Third Maximum Number