难度系数: 中等
编写 SQL 查询对分数进行排序。排名按以下规则计算:
- 分数应按从高到低排列。
- 如果两个分数相等,那么两个分数的排名应该相同。
- 在排名相同的分数后,排名数应该是下一个连续的整数。换句话说,排名之间不应该有空缺的数字。
按 score 降序返回结果表。
SQL结构
1 2 3 4 5 6 7 8
| Create table If Not Exists Scores (id int, score DECIMAL(3,2)) Truncate table Scores insert into Scores (id, score) values ('1', '3.5') insert into Scores (id, score) values ('2', '3.65') insert into Scores (id, score) values ('3', '4.0') insert into Scores (id, score) values ('4', '3.85') insert into Scores (id, score) values ('5', '4.0') insert into Scores (id, score) values ('6', '3.65')
|
表:Scores
1 2 3 4 5 6 7 8
| + | Column Name | Type | + | id | int | | score | decimal | + Id是该表的主键。 该表的每一行都包含了一场比赛的分数。Score是一个有两位小数点的浮点值。
|
示例 1:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23
| 输入: Scores 表: + | id | score | + | 1 | 3.50 | | 2 | 3.65 | | 3 | 4.00 | | 4 | 3.85 | | 5 | 4.00 | | 6 | 3.65 | + 输出: + | score | rank | + | 4.00 | 1 | | 4.00 | 1 | | 3.85 | 2 | | 3.65 | 3 | | 3.65 | 3 | | 3.50 | 4 | +
|
解法:
1 2 3 4 5 6 7 8
| SELECT Score, (SELECT count(*) FROM (SELECT DISTINCT Score s FROM Scores) tmp WHERE s >= Score) Rank FROM Scores ORDER BY Score DESC
|
原题链接:https://leetcode.cn/problems/rank-scores