SQL 汇总统计及GROUP BY
创始人
2024-03-15 21:02:19
0

SQL 汇总统计

  • 1、汇总统计
  • 2、`GROUT BY`
  • 3、如何对分组统计的结果进行过滤? `GROUP BY + HAVING`
  • 4、如何对分组统计的结果进行排序?`GROUP BY + ORDER BY`
  • 5、介绍SELECT语句中各个子句的书写顺序
  • 6、备注: 上方用到的表

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、备注: 上方用到的表

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

相关内容

热门资讯

监控摄像头接入GB28181平... 流程简介将监控摄像头的视频在网站和APP中直播,要解决的几个问题是:1&...
Windows10添加群晖磁盘... 在使用群晖NAS时,我们需要通过本地映射的方式把NAS映射成本地的一块磁盘使用。 通过...
protocol buffer... 目录 目录 什么是protocol buffer 1.protobuf 1.1安装  1.2使用...
在Word、WPS中插入AxM... 引言 我最近需要写一些文章,在排版时发现AxMath插入的公式竟然会导致行间距异常&#...
Fluent中创建监测点 1 概述某些仿真问题,需要创建监测点,用于获取空间定点的数据࿰...
educoder数据结构与算法...                                                   ...
MySQL下载和安装(Wind... 前言:刚换了一台电脑,里面所有东西都需要重新配置,习惯了所...
MFC文件操作  MFC提供了一个文件操作的基类CFile,这个类提供了一个没有缓存的二进制格式的磁盘...
有效的括号 一、题目 给定一个只包括 '(',')','{','}'...
【Ctfer训练计划】——(三... 作者名:Demo不是emo  主页面链接:主页传送门 创作初心ÿ...