分数排名-数据库-力扣(LeetCode)题库

编写一个 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;

你可能感兴趣的:(leetcode,sql)