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后的成绩进行条件查询,这个有更好的办法吗?
如果你希望能够在进行学生成绩的汇总的同时对成绩进行过滤,可以使用 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 分。
是的,你可以在子查询中加上查询条件,以筛选出符合条件的数据,然后对结果进行汇总。
例如,如果你想查询学生成绩>=60分的人数,可以这样写:
SELECT 学校, COUNT(a.学号) AS 学生人数, SUM(b.学生成绩)
FROM 学校,
(SELECT * FROM 学生信息 WHERE 学生成绩 >= 60) AS a,
(SELECT * FROM 学生成绩) AS b
GROUP BY 学校;
这样,在汇总时只会统计符合条件的数据,避免了数据重复的问题。