题解 | #获得积分最多的人(三)#
获得积分最多的人(三)
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以及对应的总分如下:
二、
之后再用窗口函数取出得分排名第一的人,再把人的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