編寫乙個 sql 查詢來實現分數排名。
如果兩個分數相同,則兩個分數排名(rank)相同。請注意,平分後的下乙個名次應該是下乙個連續的整數值。換句話說,名次之間不應該有「間隔」。
±—±------+例如,根據上述給定的 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 |
±------±-----+
涉及到排名問題,可以使用視窗函式
專用視窗函式rank, dense_rank, row_number有什麼區別呢?
它們的區別我舉個例子,你們一下就能看懂:
下圖是"班級"表中的內容,記錄了每個學生所在班級,和對應的成績。
現在需要按成績來排名,如果兩個分數相同,那麼排名要是並列的。
#mysql
select*,
rank(
)over
(order
by 成績 desc
)as ranking,
dense_rank(
)over
(order
by 成績 desc
)as dese_rank,
row_number(
)over
(order
by 成績 desc
)as row_num
from 班級表
;
結果
178 分數排名
編寫乙個 sql 查詢來實現分數排名。如果兩個分數相同,則兩個分數排名 rank 相同。請注意,平分後的下乙個名次應該是下乙個連續的整數值。換句話說,名次之間不應該有 間隔 例如,根據上述給定的 scores 表,你的查詢應該返回 按分數從高到低排列 例如,根據上述給定的 scores 表,你的查詢...
178 分數排名
sql架構 編寫乙個 sql 查詢來實現分數排名。如果兩個分數相同,則兩個分數排名 rank 相同。請注意,平分後的下乙個名次應該是下乙個連續的整數值。換句話說,名次之間不應該有 間隔 id score 1 3.50 2 3.65 3 4.00 4 3.85 5 4.00 6 3.65 例如,根據上...
178 分數排名
編寫乙個 sql 查詢來實現分數排名。示例 如果兩個分數相同,則兩個分數排名 rank 相同。請注意,平分後的下乙個名次應該是下乙個連續的整數值。換句話說,名次之間不應該有 間隔 id score 1 3.50 2 3.65 3 4.00 4 3.85 5 4.00 6 3.65 例如,根據上述給定...