LeetCode-Mysql-分数排名(窗口函数解决)

本文介绍了如何使用SQL的窗口函数实现分数排名,当分数相同时,排名相同且不产生间隔。以给定的Scores表为例,展示了使用dense_rank()函数按分数从高到低排列数据的方法,解释了rank()、dense_rank()和row_number()的区别,并强调了在MySQL中使用窗口函数的注意事项。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

编写一个 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    |
+-------+------+
重要提示:对于 MySQL 解决方案,如果要转义用作列名的保留字,可以在关键字之前和之后使用撇号。例如 `Rank`

解题办法:窗口函数

SELECT 
    Score,
    dense_rank() over (order by Score desc)  as 'Rank'
    -- 不指定 partition by 相当于所有行数据一个 partition, 数据进行区内排序
    -- dense_rank() 相当于每一行数据一个窗口, 对数据进行比较
    FROM Scores;


窗口函数的区别

  • rank():排名为相同时记为同一个排名, 并且参与总排序
  • dense_rank() over (PARTITION BY xx ORDER BY xx [DESC]):排名相同时记为同一个排名, 并且不参与总排序
  • row_number() over (over (PARTITION BY xx ORDER BY xx [DESC])):排名相同时记为下一个排名

窗口函数在hive sql中经常使用, 也可在 mysql 8.0 之上的版本中使用

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值