日期:2014-05-16  浏览次数:20466 次

Oracle select ---------having条件过滤与where条件过滤

HAVING 子句对 GROUP BY 子句设置条件的方式与 WHERE 子句和 SELECT 语句交互的方式类似。WHERE 子句搜索条件在进行分组操作之前应用;而 HAVING 搜索条件在进行分组操作之后应用。HAVING 语法与 WHERE 语法类似,但 HAVING 可以包含聚合函数。HAVING 子句可以引用选择列表中出现的任意项。
SELECT 字段表
??? FROM 表
??? [WHERE选择准则]
??? GROUP BY 分组字段表
??? [HAVING分组准则]

说明
HAVING 是可选的。

HAVING 与 WHERE 类似,可用来决定选择哪个记录。在使用 GROUP BY对这些记录分组后,HAVING 会决定应显示的记录,不同的是where对分组前的结果集条件过滤,而having对分组后的结果集过滤;having何以跟聚合函数,而where则不能。

以下从建立实例来理解
------------------------------------------

--建立测试环境 

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 

?

?

?

?

?

?

?