日期:2014-05-16 浏览次数:20492 次
HAVING 子句对 GROUP BY 子句设置条件的方式与 WHERE 子句和 SELECT 语句交互的方式类似。WHERE 子句搜索条件在进行分组操作之前应用;而 HAVING 搜索条件在进行分组操作之后应用。HAVING 语法与 WHERE 语法类似,但 HAVING 可以包含聚合函数。HAVING 子句可以引用选择列表中出现的任意项。 说明 HAVING 与 WHERE 类似,可用来决定选择哪个记录。在使用 GROUP BY对这些记录分组后,HAVING 会决定应显示的记录,不同的是where对分组前的结果集条件过滤,而having对分组后的结果集过滤;having何以跟聚合函数,而where则不能。 以下从建立实例来理解
? ?
SELECT 字段表
??? FROM 表
??? [WHERE选择准则]
??? GROUP BY 分组字段表
??? [HAVING分组准则]
HAVING 是可选的。
--------------------------------------------建立测试环境
Create Table TEST
(类别 Varchar(10),
产品 Varchar(10),
数量 Int)
--插入数据
Insert into TEST Values('A','A01',10);
Insert into TEST Values('A','A02',13);
Insert into TEST Values('A','A03',12);
Insert into TEST Values('A','A05',15);
Insert into TEST Values('A','A06',11);
Insert into TEST Values('A','A06',12);
Insert into TEST Values('B','B01',20);
Insert into TEST Values('B','B02',10);
Insert into TEST Values('B','B03',17);
--测试
-----1,选择类别与产品都相同的记录
select 类别,产品 from test a group by 类别,产品 having count(*)>1
---返回结果 类别 产品 A A06
-----2,选择所有记录数量大于15的记录
select 类别,产品,数量 from test a group by 类别,产品,数量 having 数量> 15
---返回结果类别 产品 数量 B B01 20 B B03 17
------3,选择类别为A的记录中数量大于12的记录
select 类别,产品,数量 from test a where 类别='A' group by 类别,产品,数量 having 数量> 12
---返回结果类别 产品 数量 A A02 13 A A05 15
------4,选择数量平均数大于13的记录 select 类别,产品,avg(数量) 平均数 from test a group by 类别,产品 having avg(数量)>13
---返回结果类别 产品 平均数 A A05 15 B B01 20 B B03 17
--删除测试环境
Drop Table TEST
?
?
?
?
?