一、
相较于上一题,只有最里面这一层子查询算总分出现了变动,我考虑的是,用增加的分数和-减去的分数和
相比其他人的答案,他们的思路是对每一条分数做出判断,是加或者是减,之后再sum,本题的运行包含了两个sum时间会长一点。

select user_id, 
 sum(if( type='add',grade_num,0))- sum(if( type='reduce',grade_num,0))as grade_sum
from grade_info 
 group by user_id
 order by grade_sum desc

id以及对应的总分如下:
id以及对应的总分
二、
之后再用窗口函数取出得分排名第一的人,再把人的name连接上

select c.id,c.name,grade_sum
from 
(select user_id,grade_sum,rank() over(order by grade_sum desc)  as rn
 from
(select user_id, 
 sum(if( type='add',grade_num,0))- sum(if( type='reduce',grade_num,0))as grade_sum
from grade_info 
 group by user_id
 order by grade_sum desc
) a
) b
join user c on b.user_id =c.id
where rn =1
order by c.id asc