【力扣白嫖日记】178.分数排名

前言

练习sql语句,所有题目来自于力扣(https://leetcode.cn/problemset/database/)的免费数据库练习题。

今日题目:

178.分数排名

表:Scores

列名 类型
id int
score decimal

在 SQL 中,id 是该表的主键。

该表的每一行都包含了一场比赛的分数。Score 是一个有两位小数点的浮点值。

查询并对分数进行排序。排名按以下规则计算:

  • 分数应按从高到低排列。
  • 如果两个分数相等,那么两个分数的排名应该相同。
  • 在排名相同的分数后,排名数应该是下一个连续的整数。换句话说,排名之间不应该有空缺的数字。
  • 按 score 降序返回结果表。

我那不值一提的想法:

  • 首先梳理表内容,题干一共给了一张分数表,记录了比赛id,以及比赛分数。
  • 其次分析需求
  • 第一个需求,分数从高到低,这个简单,order by score desc
  • 第二个需求,分数相等,分数排名一样,对排名结果进行列数字排序,这个需求我想了很久,但是没有思路,于是我看了题解
  • 看了题解我觉得比较简单易懂的有两种方法
  • 首先第一种是子查询,对于比我们高成绩的同学如果你是98分,你前面有一个同学是99分,那么你就是第二名,我们可以通过两张表来实现,第一张s1表就是你的成绩,第二张s2表就代表成绩比你好的同学,设置条件s2.score>=s1.score,然后对这一部分进行计数,你前面加你一共几个人,你就是第几名。
sql 复制代码
select s1.score,
(
    select count(distinct s2.score) 
    from Scores s2
    where s2.score >= s1.score
) as 'rank'
from Scores s1 
order by s1.score desc
  • 第二种方法就是窗口函数,当然我没有学过,这里就当是积累窗口函数的用法。这里使用dense_rank函数,dense_rank函数是 SQL 中的一种窗口函数,用于计算排名。它为结果集中的每一行分配一个排名值,这个值与根据特定排序条件(通常是 ORDER BY 子句)排列的行的位置相对应。与普通的 RANK() 函数不同,DENSE_RANK() 函数会跳过相同的排名,并在下一个不同的值出现时递增排名。
sql 复制代码
select score,dense_rank() over (order by score desc) as 'rank'
from Scores

虽然窗口函数代码简单,但我还是觉得子查询的逻辑更加清楚一点,更加容易懂一点。


结果:

  • 子查询
  • 窗口函数

总结:

能运行就行。


相关推荐
Navicat中国34 分钟前
如何使用 Ollama 配置 AI 助手 | Navicat 教程
数据库·人工智能·ai·navicat·ollama
小猿姐5 小时前
实测对比:哪款开源 Kubernetes MySQL Operator 最值得用?(2026 深度评测)
数据库·mysql·云原生
倔强的石头_7 小时前
从 “存得下” 到 “算得快”:工业物联网需要新一代时序数据平台
数据库
TDengine (老段)8 小时前
TDengine IDMP 可视化 —— 分享
大数据·数据库·人工智能·时序数据库·tdengine·涛思数据·时序数据
GottdesKrieges9 小时前
OceanBase数据库备份配置
数据库·oceanbase
SPC的存折9 小时前
MySQL 8组复制完全指南
linux·运维·服务器·数据库·mysql
运维行者_9 小时前
OpManager MSP NetFlow Analyzer集成解决方案,应对多客户端网络流量监控挑战
大数据·运维·服务器·网络·数据库·自动化·运维开发
语戚9 小时前
力扣 968. 监控二叉树 —— 贪心 & 树形 DP 双解法递归 + 非递归全解(Java 实现)
java·算法·leetcode·贪心算法·动态规划·力扣·
skywalker_1110 小时前
力扣hot100-7(接雨水),8(无重复字符的最长子串)
算法·leetcode·职场和发展
炸炸鱼.11 小时前
Python 操作 MySQL 数据库
android·数据库·python·adb