【随手记】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,数据库)