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子句中能够。