Write a SQL query to rank scores. If there is a tie between two scores, both should have the same ranking. Note that after a tie, the next ranking number should be the next consecutive integer value. In other words, there should be no “holes” between ranks.
1 | +----+-------+ |
For example, given the above Scores
table, your query should generate the following report (order by highest score):
1 | +-------+---------+ |
Important Note: For MySQL solutions, to escape reserved words used as column names, you can use an apostrophe before and after the keyword. For example Rank
.
1 利用count(distinct)
对于任意一个值a, 这个值的排名就等于大于等于a的所有值去重之后的个数.
1 | # Write your MySQL query statement below |
2 窗口函数
不得不说, 窗口函数是真香
在MySQL里Rank是保留字, 所以要用as 'Rank'
而不是 as Rank
1 | # Write your MySQL query statement below |