zoukankan      html  css  js  c++  java
  • 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
    

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

  • 相关阅读:
    basis 文档
    profile default1
    profile default
    2101244
    Linux下对lvm逻辑卷分区大小的调整(针对xfs和ext4不同文件系统)
    1816647
    lvm管理:扩展lv、删除pv、lv等
    HPUX and AIX SSH 互信
    SLD Related Gateway Serivces Unavaliable
    [原创]K8 MSF Bind Shell TCP 连接工具
  • 原文地址:https://www.cnblogs.com/haiya2019/p/10627735.html
Copyright © 2011-2022 走看看