编写一个 SQL 查询来实现分数排名。
如果两个分数相同,则两个分数排名(Rank)相同。请注意,平分后的下一个名次应该是下一个连续的整数值。换句话说,名次之间不应该有“间隔”。
+----+-------+
| Id | Score |
+----+-------+
| 1 | 3.50 |
| 2 | 3.65 |
| 3 | 4.00 |
| 4 | 3.85 |
| 5 | 4.00 |
| 6 | 3.65 |
+----+-------+
例如,根据上述给定的 Scores 表,你的查询应该返回(按分数从高到低排列):
+-------+------+
| Score | Rank |
+-------+------+
| 4.00 | 1 |
| 4.00 | 1 |
| 3.85 | 2 |
| 3.65 | 3 |
| 3.65 | 3 |
| 3.50 | 4 |
+-------+------+
重要提示:对于 MySQL 解决方案,如果要转义用作列名的保留字,可以在关键字之前和之后使用撇号。例如 Rank
来源:力扣(LeetCode)
题目链接:https://leetcode-cn.com/problems/rank-scores
参考答案:
方法一:
SELECT
a.Score,
COUNT(DISTINCT b.Score) AS 'Rank' # 统计b表不重复的分数的数量作为排名
FROM
Scores a JOIN Scores b
WHERE
a.Score <= b.Score # 条件是b表分数不小于a表,因为a、b表的数据相同,所以排名值是1
GROUP BY a.Id #a表中每个数据都进行排名
ORDER BY a.Score DESC; # 最后按分数降序排列
利用 自连接的方法 将一张表 分为两张相同的表 (起别名为a,b),
将b表的分数去重,
然后将a表的分数与b表的分数进行比较,
找出b表中有多少个大于、等于该分数的不同的分数,
最后根据成绩进行降序
方法二
采用函数 DENSE_RANK() 进行排序
SELECT Score,
dense_rank() over(ORDER BY Score DESC) 'Rank'
FROM Scores;