本文主要是介绍LeetCode数据库题目Oracle解答:178. 分数排名,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
编写一个 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 |
+-------+------+
解题思路:
总体思路利用oracle的rownum实现(思路与177. 第N高的薪水 一样)
1.倒序取出所有不重复的score
2.利用rownum进行标记排名
3.最后与Scores表进行左连接
答案:
/* Write your PL/SQL query statement below */
SELECT a.score,b.rank
FROM Scores a
LEFT JOIN (SELECT score,rownum AS rank --2.利用rownum进行标记排名FROM (SELECT DISTINCT scoreFROM ScoresORDER BY score DESC --1.倒序取出所有不重复的score)) b ON a.score = b.score --3.最后与Scores表进行左连接
ORDER BY score DESC
这篇关于LeetCode数据库题目Oracle解答:178. 分数排名的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!