赞
踩
当使用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。该函数的作用是按照指定的列的值对行进行排序,并为相同值的行分配相同的排名,连续计数下去。
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。