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

获得积分最多的人(三)

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

/*
select info.user_id, u.name, sum(case when info.type = 'add' then info.grade_num * 1
           when info.type = 'reduce' then info.grade_num * (-1)
           end) as grade_sum
FROM grade_info as info
left JOIN user as u
ON u.id = info.user_id
GROUP BY user_id
*/
SELECT id, name, grade_sum
FROM (select info.user_id as id, u.name as name, sum(case when info.type = 'add' then info.grade_num * 1
           when info.type = 'reduce' then info.grade_num * (-1)
           end) as grade_sum, 
           DENSE_RANK() over(order BY sum(case when info.type = 'add' then info.grade_num * 1
           when info.type = 'reduce' then info.grade_num * (-1)
           end) DESC) as r
FROM grade_info as info
left JOIN user as u
ON u.id = info.user_id
GROUP BY user_id) as t
where r = 1;
全部评论

相关推荐

点赞 收藏 评论
分享
牛客网
牛客企业服务