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

获得积分最多的人(三)

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

思路:
1\ 对所有add 和 reduce分数相加
2\ grade_add - grade_reduce, 并且用窗口函数保留最大的分数
3\ 输出 总分数 >= 最大分 的用户

SELECT
id,name,grade_sum
from(
SELECT
distinct
id,
name,
(grade_add - grade_reduce) as grade_sum,
max(grade_add - grade_reduce) over() as max_grade
from(
SELECT
t1.id,
t1.name,
sum(case when type = 'add' then grade_num else 0 end) as grade_add,
sum(case when type = 'reduce' then grade_num else 0 end) as grade_reduce
from user t1
left join grade_info t2
on t1.id = t2.user_id
group by t1.id,
t1.name
) t
) tt
where grade_sum >= max_grade
全部评论

相关推荐

昨天 13:08
蚌埠坦克学院 C++
服从性笔试吗,发这么多笔,现在还在发。
蟑螂恶霸zZ:傻 x 公司,发两次笔试,两次部门匹配挂,
投递金山WPS等公司10个岗位 >
点赞 评论 收藏
分享
过往烟沉:我说什么来着,java就业面就是广!
点赞 评论 收藏
分享
点赞 收藏 评论
分享
牛客网
牛客企业服务