Leetcode 178. 分數排名
阿新 • • 發佈:2018-11-13
編寫一個 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 | +-------+------+
思路:RANK,用統計查詢表中有多少不重複>=當前分數的個數,即為排名。通過計算欄位子查詢。
select s1.Score,(select count(DISTINCT Score) from Scores as s2 where s2.Score>=s1.Score) as Rank from Scores as s1 Order by Score DESC