当使用ROW_NUMBER()
函数、RANK()
函数和DENSE_RANK()
函数对一列数进行排名时,它们的用法和结果会有一些区别。
假设有一个名为students
的表,包含学生的姓名和分数信息。
+----+-------+--------+ | ID | Name | Score | +----+-------+--------+ | 1 | Alice | 80 | | 2 | Bob | 85 | | 3 | Cathy | 90 | | 4 | David | 90 | | 5 | Emma | 95 | +----+-------+--------+
- 使用
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()
函数会为每一行分配一个唯一的数字,按照分数降序排名。注意,分数相同的行会有不同的排名。
- 使用
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。
- 使用
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。该函数的作用是按照指定的列的值对行进行排序,并为相同值的行分配相同的排名,连续计数下去。