返回顶部
首页 > 资讯 > 数据库 >SQL 汇总统计及GROUP BY
  • 397
分享到

SQL 汇总统计及GROUP BY

sqlmysql数据库sqlserversqlite 2023-09-05 11:09:16 397人浏览 薄情痞子
摘要

sql 汇总统计 1、汇总统计2、`GROUT BY`3、如何对分组统计的结果进行过滤? `GROUP BY + HAVING`4、如何对分组统计的结果进行排序?`GROUP BY +

sql 汇总统计

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 > 80GROUP BY class_id

汇总原理如下:
请添加图片描述

如何统计不同的交易所的总的买入金额?

SELECT LEFT(stock_code,2), SUM(price * volume)FROM t_stock_trans_dtlWHERE opt_typ = '买入'GROUP BY LEFT(stock_code,2)

如何统计不同的交易所的不同交易类型的总的交易金额?

SELECT LEFT(stock_code,2), opt_typ, SUM(price * volume)FROM t_stock_trans_dtlGROUP BY LEFT(stock_code,2), opt_typ

SELECT里除了使用聚集函数返回的字段外,其他所有的字段都必须原样出现在GROUP BY的 后面;

GROUP BY会将NULL值的行,分到同一组计算统计值:

SELECT teacher_id, COUNT(*)FROM studentGROUP BY teacher_id

请添加图片描述

3、如何对分组统计的结果进行过滤? GROUP BY + HAVING

如何获取教授15名以上学名的老师?
使用关键字:GROUP BY + HAVING

SELECT teacher_id, COUNT(*)FROM studentGROUP BY teacher_idHAVING COUNT(*) > 15

如何获取数学成绩平均分在70分及以上的班级?

SELECT class_id, AVG(score)FROM studentGROUP BY class_idHAVING AVG(score) > 70;

如何获取每个班级的成绩平均分(不计算成绩在80分以下的学
生且过滤掉平均分在90分以下的班级),以便比较不同班级的成绩?

SELECT class_id, AVG(score)FROM studentWHERE score > 80GROUP BY class_idHAVING AVG(score) > 90;

请添加图片描述

4、如何对分组统计的结果进行排序GROUP BY + ORDER BY

如何获取每个班级的数学成绩平均分(不计算成绩在80分以下的学
生),然后以平均分从高到低排序?

SELECT class_id, AVG(score)FROM studentWHERE score > 80GROUP BY class_idORDER BY AVG(score) DESC

请添加图片描述

5、介绍SELECT语句中各个子句的书写顺序

如何获取每个班级的数学成绩平均分(不计算成绩在80分以下的学
生且过滤掉平均分在90分以下的班级),然后以平均分从高到低排序?

SELECT class_id, AVG(score)FROM studentWHERE score > 80GROUP BY class_idHAVING AVG(score) > 90ORDER BY AVG(score) DESC

请添加图片描述

6、备注: 上方用到的表

学生表
请添加图片描述
交易表
请添加图片描述

来源地址:https://blog.csdn.net/liyunxiangrxm/article/details/128150913

您可能感兴趣的文档:

--结束END--

本文标题: SQL 汇总统计及GROUP BY

本文链接: https://lsjlt.com/news/395143.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作