题解 | #每类试卷得分前3名#

每类试卷得分前3名

https://www.nowcoder.com/practice/255aa1863fe14aa88694c09ebbc1dbca

SELECT * FROM
(SELECT a.tag tid,
       b.uid uid,
       ROW_NUMBER() OVER(PARTITION BY a.tag ORDER BY MAX(b.score) DESC, MIN(b.score) DESC,  MAX(b.uid) DESC) ranking
FROM examination_info a
    JOIN exam_record b
    USING(exam_id )
GROUP BY tid, uid) T
HAVING ranking <= 3
# WHERE ranking <= 3

ROW_NUMBER() 唯一排名 1,2,3

RANK() 重复且跳过 1,1,3,3,5

DENSE_RANK() 重复但不跳过 1,1,2,2,2,3

题目要求找到每类试卷得分的前三名,排序条件是先根据最大得分,再根据最小得分、用户id

所以使用ROW_NUMBER(),再把这个排序条件显式化

前三名,就筛选出ranking <=3的,不知道为啥HAVING 也对,我是想直接一个查询解决问题的,但是报错

全部评论

相关推荐

感觉他们一点都不了解现在这个社会就业有多难,已经在牛客刷到好多篇&nbsp;延毕的帖子了,延毕就会导致已经找好的工作就没了,还得重新再找,学校和老师们是怎么想的呢????看到学生丢失工作会开心吗&nbsp;就业数据都在造假,真实的就业困难不去解决&nbsp;一个个真是好样的
从明天开始狠狠卷JV...:学生看到的是导师不放实习导致offer黄了。 导师看到的是招进来的学生吃自己补助和自己的招生名额,却没给自己升迁带来任何帮助,还要跑路。 根本利益的不一致,最主要留校的导师大概率是职场上招聘失败的,被迫留校的,什么牛鬼蛇神都会有
点赞 评论 收藏
分享
“校招”、“3-5年经验”
飞花断音:小公司招逆向的不要去,基本上都是搞黑灰产违法的东西
点赞 评论 收藏
分享
晗江雪:其实我只是觉得你们导员说的很好笑
点赞 评论 收藏
分享
程序员牛肉:主要是因为小厂的资金本来就很吃紧,所以更喜欢有实习经历的同学。来了就能上手。 而大厂因为钱多,实习生一天三四百的就不算事。所以愿意培养你,在面试的时候也就不在乎你有没有实习(除非是同级别大厂的实习。) 按照你的简历来看,同质化太严重了。项目也很烂大街。 要么换项目,要么考研。 你现在选择工作的话,前景不是很好了。
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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