当前位置:网站首页>leetcode day1 分数排名
leetcode day1 分数排名
2022-07-28 17:47:00 【wyqgg123】
Mysql
178. 分数排名
难度中等
SQL架构
编写一个 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
题解1:专用窗口函数dense_rank
select `Score`,
dense_rank() over (Order by Score desc) as `Rank`
from Scores;
运行结果:

dense_rank函数有并列名次的行不会占用下一名的位置,也就是1、1、2、3、3、4。 这样排名。
扩展:
mysql四大排序函数:
示例:
select `Score`,
dense_rank() over (Order by Score desc) as `Rank` ,
rank() over (Order by Score desc) as `Rank1`,
row_number() over (Order by Score desc) as `Rank2`
from Scores;
运行结果:

由运行结果可知:
1、rank函数:结果1、1、3、4、4、6 也就是如果有并列名次的行,会占用下一名次的位置。
2、dense_rank函数:结果:1、1、2、3、3、4,也就是如果有并列名次的行,不占用下一名次的位置。
3、row_number函数:结果1、2、3、4、5、6,也就是不考虑并列名次的情况。
第四个排序函数为:
示例:
select `Score`,
ntile(1) over (Order by Score desc) as `Rank1`,
ntile(2) over (Order by Score desc) as `Rank2`,
ntile(3) over (Order by Score desc) as `Rank3`,
ntile(4) over (Order by Score desc) as `Rank4`,
ntile(5) over (Order by Score desc) as `Rank5`,
ntile(6) over (Order by Score desc) as `Rank6`,
ntile(7) over (Order by Score desc) as `Rank7`
from Scores;
结果:

ntile(1) : 结果 1、1、1、1、1、1
ntile(2) : 结果 1、1、1、2、2、2
ntile(3) : 结果 1、1、2、2、3、3
ntile(4) : 结果 1、1、2、2、3、4
ntile(5) : 结果 1、1、2、3、4、5
ntile(6) : 结果 1、2、3、4、5、6
ntile(7) : 结果 1、2、3、4、5、6
由运行结果可知nitile就是按照分组排序,参数为几时就是分几组排序。
题解二:
示例
select a.Score as Score,
(select count(distinct b.Score) from Scores as b where b.Score>=a.score)as `Rank`
from Scores as a
order by a.Score desc;
解读:
子查询中将全部的大于等于当前分数的分数去重取总数,这样就是该分数应该有的名次,以该题为例:
score : 4.00 — rank :1 大于等于4的有两个都是4去重后为 1 。
score : 4.00 — rank: 1 大于等于4的有两个都是4去重后为 1 。
score : 3.85 — rank: 2 大于等于3.85的有3个4、4、3.85去重后为 2 。
score : 3.65 — rank : 3 大于等于3.65的有5个4、4、3.85、3.65、3.65去重后为 3 。
score : 3.65 — rank : 3 大于等于3.65的有5个4、4、3.85、3.65、3.65去重后为 3 。
score : 3.50 — rank : 4 大于等于3.65的有5个4、4、3.85、3.65、3.65、3.50去重后为 4 。
边栏推荐
- 架构基本概念和架构本质
- Left alignment function of Lua language (handwriting)
- In order to develop high-end photoresist, Jingrui Co., Ltd. invested 75million yuan to purchase SK Hynix ASML lithography machine
- Convertible bond concept table x notation gives you a convenient and fast experience!
- 微信公众号授权登录后报redirect_uri参数错误的问题
- Using Baidu easydl to realize chef hat recognition of bright kitchen and stove
- MATLAB实现的图像分割之边缘检测和连接
- SaltStack入门
- MySQL performance testing tool sysbench learning
- 为研发高端光刻胶,晶瑞股份斥资7500万元购买SK海力士的ASML光刻机
猜你喜欢

idea properties文件显示\u不显示中文的解决

2022年全国最新消防设施操作员(中级消防设施操作员)题库及答案

Nips18 (AD) - unsupervised anomaly detection using geometric transformations using geometric augmentation

远光软件获得阿里云产品生态集成认证,携手阿里云共建新合作

使用SaltStack自动化部署LNMP

When CNN meets transformer cmt:revolutionary neural networks meet vision transformers

彻底理解位运算——与(&)、非(~)、或(|)、异或(^)

基于C语言的信息管理系统和小游戏

App自动化测试是怎么实现H5测试的

How does app automated testing achieve H5 testing
随机推荐
SaltStack之salt-ssh
Sudo rosdep init error: cannot download default
Report redirect after authorized login on wechat official account_ The problem of wrong URI parameters
ES6's new data container map
【经验之谈】关于维修电子设备的几点建议和经验
R language and data analysis practice 11 - data deletion
idea properties文件显示\u不显示中文的解决
After reading the thesis for three years, I learned to read the abstract today
Test Development Notes
JS preventDefault() 键盘输入限制 onmousewheel stopPropagation停止事件传播
shared_ PTR and make_ Use of shared
How does app automated testing achieve H5 testing
投资35.45亿元!格力集团参与小米产业基金
[solved] ac86u ml revision firmware virtual memory creation failed, prompting that the USB disk reading and writing speed does not meet the requirements
文章翻译软件-批量免费翻译软件支持各大翻译接口
助力面板行业创新,FPGA将成屏厂TCON最佳选择?
Getting started with saltstack
VAE: understanding and implementation of variational self encoder
BLDC 6-step commutation simulink
leetcode day3 查找重复的电子邮箱