一. 需求分析
我们在学习数据库查询时,经常会遇到关于分组和聚合函数的查询,比如查询每门课程的最高分,每位同学的平均分,其实这些都是比较一般的问题。但如果遇到查询每门课程成绩的前几名问题,就会变的很棘手,今天老谢给你唠唠这方面的问题。
比如我们现在有如下三个表:学生表、科目表、成绩表,分别如下:
1. 学生表()
2. 科目表()
3. 成绩表(score)
现在如果我们需要获取每门科目前三名同学的姓名、学号、科目、成绩等信息,这该如何查询实现呢?
二. 具体实现
其实遇到这种问题,并不单纯是在考察我们的SQL水平,同时也是在考察我们的思考能力,我们得学会思考如何进行查询,如何进行分组聚合函数,如何进行条件过滤。
1. 先连接查询
首先我们可以根据科目和成绩,来查询同一科目中分数较高的数据。
SELECT *
FROM score s1
LEFT JOIN score s2 ON s1.subject_id = s2.subject_id AND s2.score > s1.score
这样查询到的就是一个成绩记录,同一个科目全部比他分数高的成绩记录就是被关联查询出来。这里为了让第一名也查询出来,我们可以使用外连接进行查询。
2. 再分组过滤
然后我们可以根据学生和科目再进行分组,查询出比这个学生该门科目高的学生成绩条数是多少,如果条数小于3,这样就得到了前三名。
SELECT s1.student_id, s1.subject_id
FROM score s1
LEFT JOIN score s2 ON s1.subject_id = s2.subject_id AND s2.score > s1.score
GROUP BY s1.student_id, s1.subject_id
HAVING count(*) <=2
ORDER BY s1.subject_id
如果出现了并列的情况,也会被查询出来。
现在你可以思考一个问题,如果是让你查询第2到第5名同学呢?请持续关注Java架构栈,我们会持续为你带来更多的技术干货。如果大家有任何问题,都可以在留言区留言聚合函数,我们会及时给大家回复哦。
限时特惠:本站持续每日更新海量各大内部创业课程,一年会员仅需要98元,全站资源免费下载
点击查看详情
站长微信:Jiucxh
声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。