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

本文讲述了作者在面试中遇到的一道SQL题目,要求在没有limit、first等高级函数的情况下,查询成绩排名在第10到第20的学生。作者分享了自己的思考过程,提出了一种利用自关联解决的方法,并表达了对其他四种解决方案的探索渴望。
摘要由CSDN通过智能技术生成

昨天一大清早,睡眼惺忪着就跑去陆家嘴某金融数据公司面一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

评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值