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

获得积分最多的人(三)

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

SELECT id,name,grade_sum
FROM
(-- 获得每个人对应的总分数grade_sum
	SELECT  user_id,
                grade_sum,
                RANK() OVER(ORDER BY t.grade_sum DESC) AS rk
	FROM
	(
		SELECT  user_id,
                        SUM(IF(type = 'add',grade_num, -grade_num)) AS grade_sum
		FROM grade_info
                GROUP BY user_id
	) AS t
) AS m
JOIN user AS n
ON n.id = m.user_id
WHERE rk = 1

全部评论

相关推荐

程序员花海:实习和校招简历正确格式应该是教育背景+实习+项目经历+个人评价 其中项目经历注意要体现业务 实习经历里面的业务更是要自圆其说 简历模板尽可能保持干净整洁 不要太花哨的
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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