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

获得积分最多的人(三)

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
全部评论

相关推荐

不愿透露姓名的神秘牛友
07-02 17:28
25届每天都在焦虑找工作的事情0offer情绪一直很低落硬撑着面了一个岗位岗位有应酬的成分面试的时候hr给我出各种场景题问的问题比较犀利 有点压力面的感觉感觉有点回答不上来本来就压抑的情绪瞬间爆发了呢一瞬间特别想哭觉得自己特别没用没绷住掉眼泪了事后想想觉得自己挺有病的 真的破大防了
喜欢唱跳rap小刺猬...:我觉得没关系吧,之前有一次面试leader给我压力面,我顶住了压力,结果入职的时候发现组里氛围很差,果断跑路。其实从面试就能大概看出组的情况,面试体验好的组倒是不一定好,但是面试体验不好的组。。。就很难说
点赞 评论 收藏
分享
07-02 13:52
门头沟学院 Java
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务