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

获得积分最多的人(三)

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

相关推荐

能干的三文鱼刷了10...:公司可能有弄嵌入式需要会画pcb的需求,而且pcb能快速直观看出一个人某方面的实力。看看是否有面试资格。问你问题也能ai出来,pcb这东西能作假概率不高
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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