Group by having用法_Group by与having理解
2014-03-18 11:25:23  By: dwtedx

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子句中可以

若资源对你有帮助、浏览后有很大收获、不妨小额打赏我一下、你的鼓励是维持我不断写博客最大动力

想获取DD博客最新代码、你可以扫描下方的二维码、关注DD博客微信公众号(ddblogs)

或者你也可以关注我的新浪微博、了解DD博客的最新动态:DD博客官方微博(dwtedx的微博)

如对资源有任何疑问或觉得仍然有很大的改善空间、可以对该博文进行评论、希望不吝赐教

为保证及时回复、可以使用博客留言板给我留言: DD博客留言板(dwtedx的留言板)

感谢你的访问、祝你生活愉快、工作顺心、欢迎常来逛逛


快速评论


技术评论

  • 该技术还没有评论、赶快抢沙发吧...
DD记账
top
+