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

获得积分最多的人(三)

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

select distinct id,name, grade_num from(
select id,name, dense_rank() over (order by grade_num desc) as rk,grade_num
from(
    SELECT 
  u.id, 
  u.name, 
  SUM(CASE WHEN g.type = 'add' THEN g.grade_num ELSE -g.grade_num END) AS grade_num
FROM user u
JOIN grade_info g ON u.id = g.user_id
GROUP BY u.id, u.name
)a)b
where rk=1


知道上一题为啥有重复了,因为用了sum的窗口函数,所以每条都回给出一个结果,应该去使用sum

全部评论

相关推荐

渐好:软光栅真的写明白了吗,既然是软渲那技术栈不应该使用OpenGL,光追和bvh既不算什么高级渲染技术更不应该属于软渲的内容,git那个项目没啥用,建议把前两个项目重新组织一下语言,比如软渲染那个项目 冯着色和msaa、贴图这几项分开写,写的到位点,如果你还学过光追那就单独写出来,如果没把握考官问你答不上来就别写给自己找麻烦,在技术栈那一栏简单提一下自己学过就行,这样杂的放在一起不太严谨,个人愚见.
点赞 评论 收藏
分享
xwqlikepsl:感觉很厉害啊,慢慢找
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务