1.題目描述 編寫一個 SQL 查詢來實現分數排名。如果兩個分數相同,則兩個分數排名(Rank)相同。請註意,平分後的下一個名次應該是下一個連續的整數值。換句話說,名次之間不應該有“間隔”。 例如,根據上述給定的 Scores 表,你的查詢應該返回(按分數從高到低排列): 2.思路 以這個id為4的 ...
1.題目描述
編寫一個 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 | +-------+------+
2.思路
以這個id為4的舉例,我們需要確定3.85排第幾名,是不是只需要確定分數比3.85高的有幾個人,那麼就可以確定3.85排第幾名。
比如說 比3.85 高的有id為3的和id為5,但他們同為4分,所以我們得根據成績去重!
3.代碼
select Score,(select count(distinct Score) from Scores s where s.Score>s1.Score)+1 Rank
from Scores as s1 order by s1.Score desc