SQL汇总统计与GROUP BY过滤查询实现
作者:黑码哥
1、汇总统计
介绍几个聚集函数
有多少名学生
SELECT COUNT(*) FROM student;
SELECT COUNT(1) FROM student;
SELECT COUNT(score) FROM student;
所有学生的成绩总和
SELECT SUM(score) FROM student;
所有学生成绩的最高分
SELECT MAX(score) FROM student;
所有学生成绩最低分
SELECT MIN(score) FROM student;
所有学生成绩平均分
SELECT AVG(score) FROM student;
2、GROUT BY
如何获取每个班级的数学成绩平均分(因为学生太多,这里先不计算
成绩在80分以下的学生),以便比较不同班级的成绩?
SELECT class_id, AVG(score) FROM student WHERE score > 80 GROUP BY class_id
汇总原理如下:
如何统计不同的交易所的总的买入金额?
SELECT LEFT(stock_code,2), SUM(price * volume) FROM t_stock_trans_dtl WHERE opt_typ = '买入' GROUP BY LEFT(stock_code,2)
如何统计不同的交易所的不同交易类型的总的交易金额?
SELECT LEFT(stock_code,2), opt_typ, SUM(price * volume) FROM t_stock_trans_dtl GROUP BY LEFT(stock_code,2), opt_typ
SELECT里除了使用聚集函数返回的字段外,其他所有的字段都必须原样出现在GROUP BY的 后面;
GROUP BY会将NULL值的行,分到同一组计算统计值:
SELECT teacher_id, COUNT(*) FROM student GROUP BY teacher_id
3、如何对分组统计的结果进行过滤
GROUP BY + HAVING
如何获取教授15名以上学名的老师?
使用关键字:GROUP BY + HAVING
SELECT teacher_id, COUNT(*) FROM student GROUP BY teacher_id HAVING COUNT(*) > 15
如何获取数学成绩平均分在70分及以上的班级?
SELECT class_id, AVG(score) FROM student GROUP BY class_id HAVING AVG(score) > 70;
如何获取每个班级的成绩平均分(不计算成绩在80分以下的学
生且过滤掉平均分在90分以下的班级),以便比较不同班级的成绩?
SELECT class_id, AVG(score) FROM student WHERE score > 80 GROUP BY class_id HAVING AVG(score) > 90;
4、如何对分组统计的结果进行排序
GROUP BY + ORDER BY
如何获取每个班级的数学成绩平均分(不计算成绩在80分以下的学
生),然后以平均分从高到低排序?
SELECT class_id, AVG(score) FROM student WHERE score > 80 GROUP BY class_id ORDER BY AVG(score) DESC
5、介绍SELECT语句中各个子句的书写顺序
如何获取每个班级的数学成绩平均分(不计算成绩在80分以下的学
生且过滤掉平均分在90分以下的班级),然后以平均分从高到低排序?
SELECT class_id, AVG(score) FROM student WHERE score > 80 GROUP BY class_id HAVING AVG(score) > 90 ORDER BY AVG(score) DESC
6、上方用到的表
学生表
交易表
到此这篇关于SQL汇总统计与GROUP BY过滤查询实现的文章就介绍到这了,更多相关SQL GROUP BY内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!