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

来源:互联网 发布:自助装修软件 编辑:程序博客网 时间:2024/04/29 05:29
---------having条件过滤与where条件过滤
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
-------------------------------------------------------------------------------------
华丹平台函数
1,嵌套子报表函数nestedRep(srResID, isIgnBlk)
srResID:子报表标识
isIgnBlk:是否显示,可选值为true/false,默认值为false,可不写。
2,选择图表参数chartNo,当制作了多张图表时,需要与子报表一起指定对应图表,可使用此参数
写法:chartNo=图表标识