当前位置:   article > 正文

oracle中grouping函数,Oracle PL/SQL之GROUPING 函数

oracle 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.

原文链接:

http://blog.csdn.net/t0nsha/article/details/6538826

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/IT小白/article/detail/345187
推荐阅读
相关标签
  

闽ICP备14008679号