【MySQL】按平均成绩从高到低显示所有学生的所有课程的成绩以及平均成绩

在人生的道路上,不管是潇洒走一回,或者是千山独行,皆须是自己想走的路,虽然,有的人并不是很快就能找到自己的方向和道路,不过,只要坚持到底,我相信,就一定可以找到自己的路,只要找到路,就不必怕路途遥远了。

导读:本篇文章讲解 【MySQL】按平均成绩从高到低显示所有学生的所有课程的成绩以及平均成绩,希望对大家有帮助,欢迎收藏,转发!站点地址:www.bmabk.com,来源:原文

思路:
1、先查找所有学生的平均成绩

select sid,avg(degree) 
from score 
GROUP BY sid

2、再查找所有学生的所有课程的成绩

select st.sid,st.sname,co.cname,sc.degree
from score sc,course co,student st
where sc.cid=co.cid and sc.sid=st.sid

3、四表联查,并按照平均成绩从高到低排序

select st.sid,st.sname,co.cname,sc.degree,avgscore
from score sc,course co,student st,
(select sid,avg(degree) as avgscore from score 
GROUP BY sid) as nb
where sc.cid=co.cid and sc.sid=st.sid and nb.sid=st.sid
order BY avgscore desc

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/123521.html

(0)
飞熊的头像飞熊bm

相关推荐

发表回复

登录后才能评论
极客之音——专业性很强的中文编程技术网站,欢迎收藏到浏览器,订阅我们!