第六章:数据分组

一、分组

group by

  • 按照字段分组,相同字段数据被放到同一个组内
  • 分组目的是为了配合聚合函数使用
sql 复制代码
格式一:
select 字段1,字段2 聚合函数 from 表名 group by字段1,字段2;

格式二:
select 字段1,字段2 聚合函数 from 表名 where 条件 group by字段1,字段2;
sql 复制代码
例子
-- 查询表中男女各有多少人数
select count(sex),sex from students group by sex;
sql 复制代码
-- 查询一班男女生数量
select sex,count(*) from students where class ='1班' group by sex;

练习

sql 复制代码
-- 查询表中各个年龄同学数量
select age,count(*) from students group by age;

-- 查询表中2班和4班女生各有多少人数
select class,count(sex),sex from students where 
(class = '2班' or class = '4班') and sex = '女'group by class;

-- 数据分组,统计统计各个班级学生总数,最大、最小、平均年龄,
select class,count(*),max(age),min(age),avg(age) 
from students group by class ;

where&group by &order by 同时出现使用顺序

  • where > group by > order by
sql 复制代码
select 字段, 聚合函数 from 表名 
where 条件 group by 字段 order by 字段;

/* 例子
数据分组,统计统计各个班级学生总数,最大、最小、平均年龄*/
select class,count(*),max(age),min(age),avg(age) 
from students 
where not class = '3班'  group by class order By class desc;

二、分组后进行筛选

having与where区别

  • where条件 是先筛选统计,在统计结果中分组
  • having 是先分组统计,在统计结果中筛选
  • 必须出现 group by 后面
sql 复制代码
语法
select * from 表名 group by 字段 having 条件

例子:
-- 用having查询男生总数
select count(*) from students group by sex having sex ='男';

having配合聚合函数使用

  • where后面不能使用聚合函数,having后面能使用聚合函数
sql 复制代码
-- 用having班级人数大于3人的班级
select class from students group by class having count(*)> 3;

-- 班级总人数大于2的人班级名称、班级对应人数
select class,count(*) from students 
group by class having count(*)> 2;

-- 查询平均年龄大于30班级名称、班级总人数
select class,count(*) from students 
group by class having avg(age)> 30;

-- 查询4班和2班男女人数各多少
-- 方式一:
select class,sex,count(*) from students 
GROUP BY class, sex having class = '4班' or class = '2班';
-- 方式二:
select  class,sex,count(*) from students 
where class = '4班' or class = '2班' group by class,sex;
相关推荐
ohoy3 小时前
mysql 30天自动补0
数据库·mysql
大学生资源网4 小时前
java毕业设计之儿童福利院管理系统的设计与实现(源码+)
java·开发语言·spring boot·mysql·毕业设计·源码·课程设计
Hello.Reader4 小时前
Flink SQL DELETE 语句批模式行级删除、连接器能力要求与实战避坑(含 Java 示例)
java·sql·flink
摇滚侠5 小时前
Redis 零基础到进阶,Redis 哨兵监控,笔记63-73
数据库·redis·笔记
利剑 -~5 小时前
mysql面试题整理
android·数据库·mysql
老华带你飞5 小时前
物流信息管理|基于springboot 物流信息管理系统(源码+数据库+文档)
数据库·vue.js·spring boot
程序员卷卷狗6 小时前
Redis事务与MySQL事务有什么区别?一文分清
数据库·redis·mysql
玩大数据的龙威6 小时前
农经权二轮延包—数据(新老农经权)比对软件更新
数据库·arcgis
保持低旋律节奏6 小时前
网络系统管理——期末复习
数据库
程序员佳佳7 小时前
2025年大模型终极横评:GPT-5.2、Banana Pro与DeepSeek V3.2实战硬核比拼(附统一接入方案)
服务器·数据库·人工智能·python·gpt·api