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

获得积分最多的人(三)

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

积分有增有减,可以加个if或case when 进行判断,并赋予负值;求出最高的积分可以找出最大积分进行对比找出,也可以利用开窗函数。

with gs as
(select a.id, a.name,
sum(if(b.type = 'reduce', -b.grade_num, b.grade_num)) as sum_grade
from user a left join grade_info b 
on a.id = b.user_id
group by a.id)
select gs.id as id, gs.name as name, gs.sum_grade as grade_sum from gs 
where sum_grade = (select max(sum_grade) from gs)
order by id;
全部评论

相关推荐

程序员小白条:你是沟通了900个,不是投了900份简历,你能投900份,意味着对面都要回复你900次,你早就找到实习了,没亮点就是这样的,别局限地区,时间投的也要早,现在都要7月了
点赞 评论 收藏
分享
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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