题解 | #获得积分最多的人(三)#

获得积分最多的人(三)

http://www.nowcoder.com/practice/d2b7e2a305a7499fb310dc82a43820e8

一、
相较于上一题,只有最里面这一层子查询算总分出现了变动,我考虑的是,用增加的分数和-减去的分数和
相比其他人的答案,他们的思路是对每一条分数做出判断,是加或者是减,之后再sum,本题的运行包含了两个sum时间会长一点。

select user_id, 
 sum(if( type='add',grade_num,0))- sum(if( type='reduce',grade_num,0))as grade_sum
from grade_info 
 group by user_id
 order by grade_sum desc

id以及对应的总分如下:
id以及对应的总分
二、
之后再用窗口函数取出得分排名第一的人,再把人的name连接上

select c.id,c.name,grade_sum
from 
(select user_id,grade_sum,rank() over(order by grade_sum desc)  as rn
 from
(select user_id, 
 sum(if( type='add',grade_num,0))- sum(if( type='reduce',grade_num,0))as grade_sum
from grade_info 
 group by user_id
 order by grade_sum desc
) a
) b
join user c on b.user_id =c.id
where rn =1
order by c.id asc 
全部评论
用两个sum确实是会比case when的方法,更便于阅读和逻辑理解
点赞 回复 分享
发布于 2022-08-03 13:38

相关推荐

想去夏威夷的小哥哥在度假:5和6才是重点
点赞 评论 收藏
分享
2 收藏 评论
分享
牛客网
牛客企业服务