首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 数据库 > 其他数据库 >

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

2012-09-28 
Oracle select ---------having条件过滤与where条件过滤HAVING 子句对 GROUP BY 子句设置条件的方式与 WHE

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 

?

?

?

?

?

?

?

热点排行