前言
练习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.sco

最低0.47元/天 解锁文章
940

被折叠的 条评论
为什么被折叠?



