mysql查询每个学生的各科成绩,以及总分和平均分

今天看一个mysql教程,看到一个例子,感觉里面的解决方案不是很合理。
问题如下:
有学生表:
在这里插入图片描述
成绩表:
在这里插入图片描述
想要查询出的效果:
在这里插入图片描述

其实就是原来是一个分数一条记录,现在变成一个学生一条记录。
那个教程里的sql如下:

select a.id as 学号, a.name as 姓名, 
(case when b.kemu='语文' then score else 0 end) as 语文,
(case when b.kemu='数学' then score else 0 end) as 数学,
(case when b.kemu='英语' then score else 0 end) as 英语
from student a, grade b
where a.id = b.id

实现的效果:
在这里插入图片描述
很明显,每个学生的每个成绩都是单独一条记录,那和原来没有什么区别嘛。
改进后的sql如下:

SELECT s.id, s.name, 
max(case when g.kemu='语文' then score else 0 end) as 语文,
max(case when g.kemu='数学' then score else 0 end) as 数学,
max(case when g.kemu='英语' then score else 0 end) as 英语,
sum(score) as 总分,
avg(score) as 平均分
from student s LEFT JOIN grade g ON  s.id = g.s_id GROUP BY s.id

就是使用了聚合函数,效果如下:
在这里插入图片描述
是不是比原来的效果好很多了呢

转载于:https://www.cnblogs.com/haiya2019/p/10627735.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值