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

获得积分最多的人(一)

http://www.nowcoder.com/practice/1bfe3870034e4efeb4b4aa6711316c3b

问题描述:请你写一个SQL查找积分增加最高的用户的名字,以及他的总积分是多少(此题数据保证积分最高的用户有且只有1个),以上例子查询结果如下:
结果截图

方案1:分组计算grade_num,作为临时表t,联立user表

SELECT u.name,t.grade_sum
FROM user u
INNER JOIN (  
       SELECT user_id,SUM(grade_num) AS grade_sum
       FROM grade_info
       WHERE type = 'add'
       GROUP BY user_id
       ORDER BY grade_sum DESC
       LIMIT 0,1
       ) t
ON u.id = t.user_id;

方案2:采用窗口函数

SELECT u.name,SUM(grade_num) OVER(PARTITION BY g.user_id)AS grade_sum
FROM grade_info g
INNER JOIN user u
ON g.user_id = u.id
WHERE g.type = 'add'
ORDER BY grade_sum DESC
LIMIT 0,1;
全部评论

相关推荐

程序员花海:实习太简单了 学历可以的 实习描述应该是先介绍业务 再介绍技术 技术咋推动业务的 做到了啥收益 有没有做实验 实验组和对照组有什么不同 你最后学到了什么 有没有参与处理过线上问题 有没有参与过公司的code review 有没有参与过技术分享 这些都是可以在实习描述中写的 并且实习和项目不一样不会撞车 应该放在最前面 放在教育背景下面 另外项目有点烂大街 可以看下我主页的简历优化案例
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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