??40 2023-02-12 12:09 采纳率: 100%
浏览 67
已结题

关于sql语句多表sum去重的问题

SQL语句 SUM去重的问题
有三个表,学校,学生个人信息,学生成绩。
现在按学校进行分组对学生的人数、学生的成绩进行汇总。
Select 学校,count(学号) as 学生人数,sum(学生成绩) from 学校、学生信息、学生成绩 group by 学校
但是sum会重复计算。

查询了一下,一对多关系的数据表关联后sum会产生数据重复,可以用子查询的语句。
select 学校,count(a.学号) as 学生人数,sum(b.学生成绩) from 学校、(select* from 学生信息) as a、(select * from 学生成绩) as b group by 学校

但是,如果给到查询人按条件查询(比如学生成绩>=60分的人数),以上sql语句就无法用到学生成绩表的数据进行查询,只能按sum后的成绩进行条件查询,这个有更好的办法吗?

  • 写回答

3条回答 默认 最新

  • Evaporator Core 2023-02-12 12:35
    关注

    如果你希望能够在进行学生成绩的汇总的同时对成绩进行过滤,可以使用 HAVING 子句:

    SELECT 学校, count(a.学号) as 学生人数, sum(b.学生成绩) 
    FROM 学校 
    JOIN (SELECT * FROM 学生信息) as a
    JOIN (SELECT * FROM 学生成绩) as b 
    ON a.学号 = b.学号 
    GROUP BY 学校 
    HAVING sum(b.学生成绩) >= 60;
    

    此语句将会返回每个学校学生人数和所有学生成绩的总和,同时要求学生成绩的总和大于等于 60 分。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

问题事件

  • 系统已结题 3月11日
  • 已采纳回答 3月3日
  • 创建了问题 2月12日

悬赏问题

  • ¥15 Attention is all you need 的代码运行
  • ¥15 一个服务器已经有一个系统了如果用usb再装一个系统,原来的系统会被覆盖掉吗
  • ¥15 使用esm_msa1_t12_100M_UR50S蛋白质语言模型进行零样本预测时,终端显示出了sequence handled的进度条,但是并不出结果就自动终止回到命令提示行了是怎么回事:
  • ¥15 前置放大电路与功率放大电路相连放大倍数出现问题
  • ¥30 关于<main>标签页面跳转的问题
  • ¥80 部署运行web自动化项目
  • ¥15 腾讯云如何建立同一个项目中物模型之间的联系
  • ¥30 VMware 云桌面水印如何添加
  • ¥15 用ns3仿真出5G核心网网元
  • ¥15 matlab答疑 关于海上风电的爬坡事件检测