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

# 粒度:试卷
# 对每类型试卷得分排名
# 注意点:由于SQL有两个等级,需要先去重,所以要先进行表连结
select
tag
,uid
,ranking
from
(
    select
    tag
    ,uid
    ,row_number() over(partition by tag order by max_score desc, min_score desc, uid desc) ranking
    from
    (
        select
        tag
        ,uid
        ,max(score) max_score
        , min(score) min_score
        from
        exam_record er
        join 
        examination_info ei
        on er.exam_id = ei.exam_id
        group by tag, uid
    ) A
    group by tag, uid
) B
where ranking < 4

全部评论

相关推荐

不愿透露姓名的神秘牛友
07-04 18:06
点赞 评论 收藏
分享
本2硕9,秋招不想努力海投了
小何和:行情再不好也不可能拒绝你,不可能只要双9的
点赞 评论 收藏
分享
06-15 18:44
黄淮学院 Java
Lynn012:如果是居民楼还是算了吧,看着有点野呢
点赞 评论 收藏
分享
程序员小白条:你是沟通了900个,不是投了900份简历,你能投900份,意味着对面都要回复你900次,你早就找到实习了,没亮点就是这样的,别局限地区,时间投的也要早,现在都要7月了
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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