力扣数据库刷题记录(二)

分数排名

题目

分数排名-力扣

思路

  1. 本题有两种写法,一种直接调用rank()函数,这在新版本中是支持的,并且也是效率最高的做法
  2. 另一种做法是先选出排名,利用 score >= s.score 来进行题目所需操作

代码

  1. 直接调用rank()
select Score, dense_rank() over(order by Score desc) as 'Rank' from scores;
SELECT Score, 
(SELECT count(DISTINCT score) FROM Scores WHERE score >= s.score)
AS 'Rank' FROM Scores s ORDER BY Score DESC ;

连续出现的数字

题目

连续出现的数字

思路

  1. 注意题目不是选出出现大于等于三次的数,而是连续出现大于等于三次的数,那么我们不妨列出三个相同的表r1, r2, r3
  2. 我们让表二和表一相差一位,表三和表二相差一位来进行对比,即
    r2.Id = r1.Id + 1 and r2.Id = r3.Id - 1
    并判断对应位置上的数字是否相等
    r1.Num = r2.Num and r2.Num = r3.Num
    从而选出对应的数字
  3. 再用distinct去重,最后得到结果

代码

# Write your MySQL query statement below
select distinct r2.Num as ConsecutiveNums from Logs r1, Logs r2, Logs r3
where r2.Id = r1.Id + 1 and r2.Id = r3.Id - 1 and r1.Num = r2.Num and r2.Num = r3.Num;

总结

  1. 题目1熟悉了rank()函数的用法,可以直接dense_rank() over 来进行排序
  2. 题目2实际上练习了表的连接,从而实现连续的判断
  3. 去重条件最后考虑,但是一定要考虑,不然很容易出错

以上,共勉

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值