题解 | #获得积分最多的人(三)#
获得积分最多的人(三)
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; 
