sql统计各科成绩大于平均分的人_求解: sql 数据库 检索各科成绩均大于等于该科平均成绩的学生的学号和姓名...

-- 这一部分,是查询每一个课程的平均成绩

(SELECT

课程号,

AVG(成绩) AS 平均成绩

FROM

#成绩表 a

GROUP BY

课程号

) AS 平均成绩表

-- 这个是将 平均成绩 与 成绩表 关联.

LEFT JOIN #成绩表

-- 这里是关联条件

-- 课程号匹配. 成绩要大于平均成绩

-- 学生号的条件,是和外面的学生号关联.

ON (平均成绩表.课程号 = #成绩表.课程号

AND 平均成绩表.平均成绩 < #成绩表.成绩

AND #成绩表.学生号 = #学生表.学生号)

这个子查询的结果,就是将每一个学生的成绩,都与平均成绩作比较.

如果成绩 大于 平均成绩,那么 关联结果中,包含 学生号

如果成绩 小于等于平均成绩,那么 关联结果中, 不包含 学生号,也就是那个 学生号的地方,是 NULL

你可以单独执行中间的那段子查询。

SELECT

平均成绩表.课程号,

平均成绩表.平均成绩,

#成绩表.成绩,

#成绩表.学生号

FROM

(SELECT

课程号,

AVG(成绩) AS 平均成绩

FROM

#成绩表 a

GROUP BY

课程号

) AS 平均成绩表

LEFT JOIN #成绩表

ON (平均成绩表.课程号 = #成绩表.课程号

AND 平均成绩表.平均成绩 < #成绩表.成绩

AND #成绩表.学生号 = 1)

当学生号是1,也就是全部都超过平均成绩的,所有数据都显示。

当学生号是其他的数字的时候,不满足条件的,成绩表的部分是 NULL.

那么最后的那个

WHERE

学生号 IS NULL

是和 前面的

NOT EXISTS(

结合起来使用的。

意思就是

不存在有

学生号是 NULL 的数据。

那么就是所有的成绩都超过 平均成绩了。

假如有一门成绩没超过,那么就会存在有 学生号是 NULL 的,那么就不会显示在最后的结果当中。

至于 "难道再没有稍微简单一点的做法吗?"

我想应该是有的,只不过我的水平不高,也就只能写出这个程度的SQL了。

  • 3
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值