一道简单的SQL面试题:查询成绩排名第10到第20的学生

昨天一大清早,睡眼惺忪着就跑去陆家嘴某金融数据公司面一ETL 岗。多年的数据仓库经验,自认为面试ETL岗应该问题不大,熟知却在一道简单的SQL题上被卡住了。

题目大概是这样,有一张学生成绩表S, 含有成绩,学生好,科目, 和分数(grade, student_id, subject, score) , 现在要求查出每个年级总成绩排名在第10到第20 的学生ID。

这样的问题,大家再熟悉不过了,心中也立马有了答案:

SELECT
    grade ,
    student_id
FROM
    (
        SELECT
            grade ,
            student_id row_number() over (partition BY grade ORDER BY total_score DESC) AS rank
        FROM
            (
                SELECT
                    grade ,
                    student_id ,
                    SUM(score) AS total_score
                FROM
                    S
                GROUP BY
                    grade ,
                    student_id ) AS total ) AS t
WHERE
    t.rank BETWEEN 10 AND 20

简单解释了下SQL 逻辑, 这时那面试的指出&#x

  • 0
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 5
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值