• SQL干货丨关于分组和聚合函数,如何实现查询排名?!


    一. 需求分析

    我们在学习数据库查询时,经常会遇到关于分组和聚合函数的查询,比如查询每门课程的最高分,每位同学的平均分,其实这些都是比较一般的问题。但如果遇到查询每门课程成绩的前几名问题,就会变的很棘手,今天老谢给你唠唠这方面的问题。

    比如我们现在有如下三个表:学生表、科目表、成绩表,分别如下:

    1. 学生表(student)

    2. 科目表(subject)

    3. 成绩表(score)

    现在如果我们需要获取每门科目前三名同学的姓名学号科目成绩等信息这该如何查询实现

    二. 具体实现

    其实遇到这种问题,并不单纯是在考察我们的SQL水平,同时也是在考察我们的思考能力,我们得学会思考如何进行查询,如何进行分组,如何进行条件过滤。

    1. 先连接查询

    首先我们可以根据科目和成绩,来查询同一科目中分数较高的数据。

    1. SELECT *
    2. FROM score s1 
    3. LEFT JOIN score s2 ON s1.subject_id = s2.subject_id AND s2.score > s1.score

    这样查询到的就是一个成绩记录,同一个科目全部比他分数高的成绩记录就是被关联查询出来。这里为了让第一名也查询出来,我们可以使用外连接进行查询。

    2. 再分组过滤

    然后我们可以根据学生和科目再进行分组,查询出比这个学生该门科目高的学生成绩条数是多少,如果条数小于3,这样就得到了前三名。

    1. SELECT s1.student_id, s1.subject_id
    2. FROM score s1 
    3. LEFT JOIN score s2 ON s1.subject_id = s2.subject_id AND s2.score > s1.score
    4. GROUP BY s1.student_id, s1.subject_id
    5. HAVING count(*<=2
    6. ORDER BY s1.subject_id

    如果出现了并列的情况,也会被查询出来。

    现在你可以思考一个问题,如果是让你查询第2到第5名同学呢?

    *威哥Java学习交流Q群:691533824
    加群备注:CSDN推荐

  • 相关阅读:
    Android入门第21天-Android里TextClock的使用
    【vue3页面展示代码】展示代码codemirror插件
    css:详解BFC块级格式化上下文
    【Jprofile 11.0 安装】
    山东企业ITSS认证条件
    ns2无线局域网隐藏节点仿真实验
    redis的详解和项目应用之PHP操作总结
    工作上的三个境界:能做,能做好,能持续做好
    Oracle笔记-对ROWNUM的一次理解(简单分页)
    代码随想录算法训练营 动态规划part17
  • 原文地址:https://blog.csdn.net/finally_vince/article/details/126139944