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

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: 【随手记】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
目录
相关文章
|
1月前
|
JSON 关系型数据库 MySQL
Mysql(5)—函数
MySQL提供了许多内置的函数以帮助用户进行数据操作和分析。这些函数可以分为几类,包括聚合函数、字符串函数、数值函数、日期和时间函数、控制流函数等。
70 1
Mysql(5)—函数
|
2月前
|
关系型数据库 MySQL 索引
mysql中EXISTS用法注意点
mysql中EXISTS用法注意点
|
12天前
|
关系型数据库 MySQL Serverless
MySQL函数
最常用的MySQL函数,包括聚合函数,字符串函数,日期时间函数,控制流函数等
|
16天前
|
SQL NoSQL 关系型数据库
|
1月前
|
存储 SQL 关系型数据库
MySQL 存储函数及调用
MySQL 存储函数及调用
52 3
|
1月前
|
缓存 关系型数据库 MySQL
MySQL 满足条件函数中使用查询最大值函数
MySQL 满足条件函数中使用查询最大值函数
120 1
|
2月前
|
存储 SQL 关系型数据库
MySQL基础:函数
本文介绍了MySQL中几种常用的内建函数,包括字符串函数、数值函数、日期函数和流程函数。字符串函数如`CONCAT()`用于拼接字符串,`TRIM()`用于去除字符串两端的空格,`MOD()`求余数,`RAND()`生成随机数,`ROUND()`四舍五入。日期函数如`CURDATE()`返回当前日期,`NOW()`返回当前日期和时间,`DATE_ADD()`添加时间间隔,`DATEDIFF()`计算日期差。流程函数如`IF()`和`CASE WHEN THEN ELSE END`用于条件判断。聚合函数如`COUNT()`统计行数,`SUM()`求和,`AVG()`求平均值
29 8
MySQL基础:函数
|
1月前
|
存储 SQL 关系型数据库
mysql用法
mysql用法
39 4
|
27天前
|
关系型数据库 MySQL 数据库
mysql中tonumber函数使用要注意什么
在处理这类转换操作时,考虑周全,利用提供的高性能云服务器资源,可以进一步提升数据库处理效率,确保数据操作的稳定性和安全性,尤其是在处理大量数据转换和运算密集型应用时。
84 0
|
1月前
|
关系型数据库 MySQL 数据处理
企业级应用 mysql 日期函数变量,干货已整理
本文详细介绍了如何在MySQL8.0中使用DATE_FORMAT函数进行日期格式的转换,包括当日、昨日及不同时间段的数据获取,并提供了实际的ETL应用场景和注意事项,有助于提升数据处理的灵活性和一致性。
40 0