Oracle PL/SQL之GROUPING 函数

在使用ROLLUP或CUBE进行GROUP操作时会产生内容为空的字段,即值为NULL的字段,那我们如何区分这些显示为空的字段到底是该字段本身值就是NULL还是由ROLLUP和CUBE生成的呢?

这时可以用GROUPING(groupingfield) 来解决,如果列中的值来自事实数据,则 GROUPING 函数返回 0;如果列中的值是ROLLUP或CUBE操作所生成的 NULL,则返回 1。

eg:

SELECT department_id deptid, job_id job, SUM (salary), GROUPING (department_id) grp_dept, GROUPING (job_id) grp_job FROM employees WHERE department_id < 50 GROUP BY ROLLUP (department_id, job_id); DEPTID JOB SUM(SALARY) GRP_DEPT GRP_JOB ---------- ---------- ----------- ---------- ---------- 10 AD_ASST 4400 0 0 10 4400 0 1 20 MK_MAN 13000 0 0 20 MK_REP 6000 0 0 20 19000 0 1 30 PU_MAN 11000 0 0 30 PU_CLERK 13900 0 0 30 24900 0 1 40 HR_REP 6500 0 0 40 6500 0 1 54800 1 1 11 rows selected.

Ref:http://blog.csdn.net/hufengwen/archive/2007/06/19/1657432.aspx

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值