当前位置: 首页 > news >正文

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

前言

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

今日题目:

178.分数排名
表:Scores

列名类型
idint
scoredecimal

在 SQL 中,id 是该表的主键。
该表的每一行都包含了一场比赛的分数。Score 是一个有两位小数点的浮点值。

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

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

我那不值一提的想法:

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

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


结果:

  • 子查询
    在这里插入图片描述
  • 窗口函数
    在这里插入图片描述

总结:

能运行就行。


相关文章:

  • 基于JavaWeb实现的校园新闻发布系统
  • 国产替代MATLAB的征途
  • 推荐收藏!科大讯飞算法岗(NLP 方向)面试题7道(含答案)
  • pytest基本应用
  • 网络安全与信创产业发展:构建数字时代的护城河
  • BFS中的多源BFS-双端队列BFS
  • 掌握 Android 中的 RecyclerView 优化
  • 中级.NET开发工程师面试经历
  • petalinux_zynq7 驱动DAC以及ADC模块之一:建立IP
  • 【论文精读】OS-Copilot: Towards Generalist Computer Agents with Self-Improvement
  • 考研408深度分析+全年规划
  • google浏览器chrome无法访问localhost等本地虚拟域名的解决方法
  • 第三章 Web 网关支持的配置
  • 微信小程序本地开发
  • http和https的区别
  • 03Go 类型总结
  • 2018天猫双11|这就是阿里云!不止有新技术,更有温暖的社会力量
  • Angular6错误 Service: No provider for Renderer2
  • co模块的前端实现
  • Java读取Properties文件的六种方法
  • Mysql5.6主从复制
  • php中curl和soap方式请求服务超时问题
  • ReactNative开发常用的三方模块
  • SpiderData 2019年2月13日 DApp数据排行榜
  • SpringCloud(第 039 篇)链接Mysql数据库,通过JpaRepository编写数据库访问
  • V4L2视频输入框架概述
  • 关键词挖掘技术哪家强(一)基于node.js技术开发一个关键字查询工具
  • 关于Android中设置闹钟的相对比较完善的解决方案
  • 记一次用 NodeJs 实现模拟登录的思路
  • 简单实现一个textarea自适应高度
  • 蓝海存储开关机注意事项总结
  • 如何使用 JavaScript 解析 URL
  • 一些基于React、Vue、Node.js、MongoDB技术栈的实践项目
  • MPAndroidChart 教程:Y轴 YAxis
  • ​MySQL主从复制一致性检测
  • #{}和${}的区别是什么 -- java面试
  • (分布式缓存)Redis持久化
  • (附源码)ssm智慧社区管理系统 毕业设计 101635
  • (个人笔记质量不佳)SQL 左连接、右连接、内连接的区别
  • (四)TensorRT | 基于 GPU 端的 Python 推理
  • (转)德国人的记事本
  • .Net 4.0并行库实用性演练
  • .NET core 自定义过滤器 Filter 实现webapi RestFul 统一接口数据返回格式
  • .NET MVC、 WebAPI、 WebService【ws】、NVVM、WCF、Remoting
  • .NET 实现 NTFS 文件系统的硬链接 mklink /J(Junction)
  • .NET/C# 使用 ConditionalWeakTable 附加字段(CLR 版本的附加属性,也可用用来当作弱引用字典 WeakDictionary)
  • .net程序集学习心得
  • /boot 内存空间不够
  • [ NOI 2001 ] 食物链
  • [ vulhub漏洞复现篇 ] Grafana任意文件读取漏洞CVE-2021-43798
  • [android] 手机卫士黑名单功能(ListView优化)
  • [Angularjs]asp.net mvc+angularjs+web api单页应用
  • [C/C++]数据结构 栈和队列()
  • [C++]C++入门--引用
  • [C++]高精度 bign (重载运算符版本)