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

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群版 2核4GB 100GB
推荐场景:
搭建个人博客
云数据库 RDS MySQL,高可用版 2核4GB 50GB
简介: 【随手记】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。该函数的作用是按照指定的列的值对行进行排序,并为相同值的行分配相同的排名,连续计数下去。

相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
7天前
|
存储 JSON 关系型数据库
mysql中find_in_set()函数用法详解及增强函数
总结而言,`FIND_IN_SET()`是MySQL中处理由逗号分隔的字符串列表的一种便捷方法,尤其适用于列表相对较短且不经常更改的场景。然而,对于更为复杂的需要高性能和可扩展性的数据库设计,它可能不是最优选择,应考虑使用更加正规化的数据库结构。
10 2
mysql中find_in_set()函数用法详解及增强函数
|
27天前
|
关系型数据库 MySQL
MySQL中CASE WHEN用法总结
MySQL中CASE WHEN用法总结
|
1月前
|
存储 关系型数据库 MySQL
mysql mysqldump用法详解
mysql mysqldump用法详解
|
1月前
|
存储 关系型数据库 MySQL
MySQL中的Decimal数据类型用法详解
MySQL中的Decimal数据类型用法详解
|
2月前
|
存储 关系型数据库 MySQL
MySQL各字符集、排序规则的由来、用法,区别和联系
MySQL支持多种字符集和排序规则,这些在数据库设计和数据处理中起着重要作用。下面是它们的由来、用法、区别和联系: 1. **字符集(Character Set)**: - **由来**:字符集定义了数据库中可以存储的字符集合,以及这些字符在数据库中的存储方式。 - **用法**:在创建数据库或表时,可以指定所需的字符集。常见的字符集包括UTF-8、UTF-16、Latin1等。 - **区别和联系**:不同的字符集支持不同的字符范围和存储方式,选择合适的字符集可以确保数据的正确存储和处理。例如,UTF-8支持全球范围内的大多数字符,而Latin1只支持西欧语言字符集。
|
1月前
|
存储 关系型数据库 MySQL
MySQL数据库——存储过程-if条件判断、参数、case(介绍、用法、案例)
MySQL数据库——存储过程-if条件判断、参数、case(介绍、用法、案例)
40 0
|
2月前
|
自然语言处理 关系型数据库 MySQL
一文明白MySQL索引的用法及好处
一文明白MySQL索引的用法及好处
51 0
|
2月前
|
关系型数据库 MySQL
MySQL union和union all的用法详解和区别
MySQL union和union all的用法详解和区别
54 0
|
2月前
|
SQL 关系型数据库 MySQL
MySQL 基本概念 基础用法 增删改查(特殊查询)语法 详细篇
MySQL 基本概念 基础用法 增删改查(特殊查询)语法 详细篇
|
2月前
|
关系型数据库 MySQL
MySQL中CONCAT() ,CONCAT_WS() ,GROUP_CONCAT()的用法
MySQL中CONCAT() ,CONCAT_WS() ,GROUP_CONCAT()的用法
26 2

推荐镜像

更多