我的编程空间,编程开发者的网络收藏夹
学习永远不晚

mysql中的group by 和 having使用

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

mysql中的group by 和 having使用

mysql中的group by 和 having 使用

理论

–sql中的group by 用法解析:
– Group By语句从英文的字面意义上理解就是“根据(by)一定的规则进行分组(Group)”。
–它的作用是通过一定的规则将一个数据集划分成若干个小的区域,然后针对若干个小区域进行数据处理。
–注意:group by 是先排序后分组;
–举例子说明:如果要用到group by 一般用到的就是“每这个字” 例如说明现在有一个这样的表:每个部门有多少人 就要用到分组的技术
select DepartmentID as ‘部门名称’,
COUNT(*) as ‘个数’ from BasicDepartment group by DepartmentID

–这个就是使用了group by +字段进行了分组,其中我们就可以理解为我们按照了部门的名称ID
–DepartmentID将数据集进行了分组;然后再进行各个组的统计数据分别有多少;
–如果不用count(*) 而用类似下面的语法
select DepartmentID,DepartmentName from BasicDepartment group by DepartmentID

–将会出现错误
–消息 8120,级别 16,状态 1,第 1 行
–选择列表中的列 ‘BasicDepartment.DepartmentName’ 无效,因为该列没有包含在聚合函数或 GROUP BY 子句中。
–这就是我们需要注意的一点,如果在返回集字段中,这些字段要么就要包含在Group By语句的后面,
–作为分组的依据;要么就要被包含在聚合函数中。
–出现的错误详解:咱们看看group by 的执行的过程,先执行select 的操作返回一个程序集,
–然后去执行分组的操作,这时候他将根据group by 后面的字段
–进行分组,并且将相同的字段并称一列数据,如果group by 后面没有这个字段的话就要分成好多的数据。
–但是分组就只能将相同的数据分成两列数据,而一列中又只能放入一个字段,所以那些没有进行分组的
–数据系统不知道将数据放入哪里,所以就出现此错误
–目前一种分组情况只有一条记录,一个数据格是无法放入多个数值的,
–所以这里就需要通过一定的处理将这些多值的列转化成单值,然后将其放在对应的
–数据格中,那么完成这个步骤的就是聚合函数。这就是为什么这些函数叫聚合函数(aggregate functions)了

–group by all语法解析:
–如果使用 ALL 关键字,那么查询结果将包括由 GROUP BY 子句产生的所有组,即使某些组没有符合搜索条件的行。
–没有 ALL 关键字,包含 GROUP BY 子句的 SELECT 语句将不显示没有符合条件的行的组。
select DepartmentID,DepartmentName as ‘部门名称’,
COUNT(*) as ‘个数’ from BasicDepartment group by all DepartmentID,DepartmentName

–group by 和having 解释:前提必须了解sql语言中一种特殊的函数:聚合函数,
–例如SUM, COUNT, MAX, AVG等。这些函数和其它函数的根本区别就是它们一般作用在多条记录上。
–WHERE关键字在使用集合函数时不能使用,所以在集合函数中加上了HAVING来起到测试查询结果是否符合条件的作用。
create TABLE Table1
(
ID int identity(1,1) primary key NOT NULL,
classid int,
sex varchar(10),
age int,
)

–添加测试数据
Insert into Table1 values(1,‘男’,20)
Insert into Table1 values(2,‘女’,22)
Insert into Table1 values(3,‘男’,23)
Insert into Table1 values(4,‘男’,22)
Insert into Table1 values(1,‘男’,24)
Insert into Table1 values(2,‘女’,19)
Insert into Table1 values(4,‘男’,26)
Insert into Table1 values(1,‘男’,24)
Insert into Table1 values(1,‘男’,20)
Insert into Table1 values(2,‘女’,22)
Insert into Table1 values(3,‘男’,23)
Insert into Table1 values(4,‘男’,22)
Insert into Table1 values(1,‘男’,24)
Insert into Table1 values(2,‘女’,19

–举例子说明:查询table表查询每一个班级中年龄大于20,性别为男的人数
select COUNT(*)as ‘>20岁人数’,classid from Table1 where sex=‘男’ group by classid,age having age>20
–需要注意说明:当同时含有where子句、group by 子句 、having子句及聚集函数时,执行顺序如下:
–执行where子句查找符合条件的数据;
–使用group by 子句对数据进行分组;对group by 子句形成的组运行聚集函数计算每一组的值;最后用having 子句去掉不符合条件的组。
–having 子句中的每一个元素也必须出现在select列表中。有些数据库例外,如oracle.
–having子句和where子句都可以用来设定限制条件以使查询结果满足一定的条件限制。
–having子句限制的是组,而不是行。where子句中不能使用聚集函数,而having子句中可以。
————————————————

测试验证


select * from Table1
在这里插入图片描述
select classid as ‘班级名称’ , COUNT(*) as ‘所有人数’ from Table1 group by classid

在这里插入图片描述

select classid as ‘班级名称’ , COUNT(*) as ‘男生人数’ from (select * from Table1 t where sex = ‘男’)Table1 group by classid

在这里插入图片描述

select COUNT(*)as ‘>20岁男生人数’,classid as '班级’from Table1 where sex=‘男’ group by classid,age having age>20;

在这里插入图片描述
select COUNT(*)as ‘女生人数’,classid as '班级’from Table1 group by classid,sex having sex = ‘女’;

在这里插入图片描述

select COUNT(*)as ‘男生人数’,classid as '班级’from Table1 group by classid,sex having sex = ‘男’;
在这里插入图片描述

来源地址:https://blog.csdn.net/BIGmustang/article/details/131089020

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

mysql中的group by 和 having使用

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

sql中group by having用法

group by 和 having 子句用于对 sql 查询结果进行分组和过滤。group by 将行划分为组,而 having 过滤满足特定条件的组。GROUP BY 和 HAVING 子句在 SQL 中的用法引言:GROUP BY 和
sql中group by having用法
2024-05-09

理解sql中的group by和having

下面通过一个例子,来简单解释group by的原理。1. GROUP BY假设我们有表1,表名为test:如果我们执行如下SQL语句:SELECT name FROM test GROUP BY name我们很容易可以得到运行的结果:为了能够更好的理解“gro
理解sql中的group by和having
2019-09-16

Mysql之分组查询,Group By,Group Having的用法

一、group by 的用法 group by ,在mysql中用来给字段分组,sql语句如下,这是一条用来统计男女数量的sql语句。 这里我们要注意到,group by ,一定是和聚合函数配合使用的,而不能直接使用select *,当然
2023-08-17

mysql中having的作用

having 子句用于对聚合结果进行筛选,具体作用包括:对分组后的数据进行筛选排除不满足条件的组基于多个条件进行筛选嵌套聚合MySQL 中 HAVING 子句的作用HAVING 子句用于对聚合结果进行筛选,它在 GROUP BY 子句之后
mysql中having的作用
2024-04-26

mysql中groupby和having的关系

group by 分组数据后,having 子句针对分组进行过滤,仅保留符合条件的分组。二者结合用于分组数据、聚合数据、过滤分组、分析数据,查找模式趋势,汇总信息和创建统计报告。MySQL 中 GROUP BY 和 HAVING 子句的关系
mysql中groupby和having的关系
2024-04-26

Where/Order by/Ggroup by/Having使用的注意事项

1、Where、Order by、Group by 、havingWhere作用对象是:基本表或视图,从中选出符合条件的元素。Order by 作用对象是:基本表或视图,就是排序方式,分为升序(ASC)和降序(DESC),排序默认为升序Group by 作用对
2019-12-06

mysql中如何使用having语句

这篇文章将为大家详细讲解有关mysql中如何使用having语句,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。说明1、用于过滤group by语句返回的记录表,通常与group by联合使用。2、havi
2023-06-20

mysql中where和having的区别

where 子句过滤行,应用于分组前;having 子句过滤组,应用于分组后且可使用组聚合函数的结果。WHERE 与 HAVING 子句的区别在 MySQL 中,WHERE 和 HAVING 子句都用于过滤数据集,但它们在作用范围和使用方
mysql中where和having的区别
2024-05-02

mysql中having的使用方法是什么

在MySQL中,HAVING子句用于在对查询结果进行分组后,对分组结果进行筛选。它与WHERE子句的区别在于,WHERE子句用于筛选行,而HAVING子句用于筛选分组。HAVING子句的一般语法如下:SELECT 列1, 列2, ...
mysql中having的使用方法是什么
2024-03-15

mysql中where和having的关系

where 子句过滤行级别数据,而 having 子句过滤组级别数据。where 子句在 from 关键字后应用,而 having 子句在 group by 关键字后应用。MySQL 中 WHERE 和 HAVING 子句的关系WHERE
mysql中where和having的关系
2024-05-01

编程热搜

目录