Oracle高级分组
/******************Oracle高级分组*****************************/
创新互联-专业网站定制、快速模板网站建设、高性价比临淄网站开发、企业建站全套包干低至880元,成熟完善的模板库,直接使用。一站式临淄网站制作公司更省心,省钱,快速模板网站建设找我们,业务覆盖临淄地区。费用合理售后完善,10余年实体公司更值得信赖。
/*-----------------auther:similarface-----------------------*/
/*--------------------2015年2月4日----------------------------*/
--oracle中GROUP BY中使用的列必须与select语句中没有使用聚合函数的列相匹配
/* Formatted on 2015/2/4 15:42:12(QP5 v5.256.13226.35538) */
SELECTd.dname,COUNT(e.empno)
FROMdeptd,empe
WHEREe.deptno(+)=D.DEPTNO
GROUPBYD.DNAME;
/* Formatted on 2015/2/4 15:47:45(QP5 v5.256.13226.35538) */
SELECTd.dname,COUNT(E.EMPNO)
FROMdeptdLEFTOUTERJOINempeONE.DEPTNO=D.DEPTNO
GROUPBYd.dname;
--GROUP BY所产生的结果可以通过HAVING子句中所给出的筛选标准来进行限制
--需求:从有雇员以来的第一个完整年开始所有至少雇佣了5名员工的部门
/* Formatted on 2015/2/4 16:22:11(QP5 v5.256.13226.35538) */
SELECT D.DNAME,TRUNC(e.hiredate,'yyyy'),COUNT(e.empno)
FROMdeptd,empe
WHERE D.DEPTNO=E.DEPTNO
GROUPBYD.DNAME,TRUNC(e.hiredate,'yyyy')
HAVING COUNT(e.empno)>5
ANDTRUNC(e.hiredate,'yyyy')BETWEEN(SELECTMIN(hiredate)
FROMemp)
AND(SELECTMAX(hiredate)
FROMemp);
--CUBE将会使得对每一行都要考虑包含CUBE参数中所有可能的元素组合
CREATETABLEtestCube
(
num1 NUMBER,
num2 NUMBER
);
INSERTINTOtestCube
VALUES(1,2);
COMMIT;
SELECT*
FROMtestCube
GROUPBYCUBE(num1,num2);
--GROUPING可以排除cube生成的空值
SELECTDECODE(GROUPING(num1),1,'NUM1',num1),
DECODE(GROUPING(num2),1,'NUM2',num2)
FROMtestCube
GROUPBYCUBE(num1,num2);
--GROUPING_ID确定其参数中的哪一行被用来生成超聚合行,然后创建一个位矢量以数值返回
WITH testGroupidAS(SELECT1 bit_1,0 bit_0FROM DUAL),
cubed
AS( SELECTGROUPING_ID(bit_1,bit_0) gid,
TO_CHAR(GROUPING(bit_1))bv_1,
TO_CHAR(GROUPING(bit_0))bv_0,
DECODE(GROUPING(bit_1),1,'GRP BIT1') gb_1,
DECODE(GROUPING(bit_0),1,'GRP BIT0') gb_0
FROMtestGroupid
GROUPBYCUBE(bit_1,bit_0))
SELECTgid,
bv_1||bv_0 bit_vector,
gb_1,
gb_0
FROMcubed
ORDERBYgid;
GROUP BY 局限性
1、LOB列,嵌套表和数组不能使用GROUPBY
2、标量子查询表达式不允许
3、GROUP BY引用对象类型列不能并行化
本文名称:Oracle高级分组
标题链接:http://scyanting.com/article/ighehg.html