Oracle PL/SQLのGROUPING関数
1417 ワード
ROLLUPまたはCUBEを使用してGROUP操作を行うと、コンテンツが空のフィールド、すなわち値がNULLのフィールドが生成されます.では、空と表示されているフィールドが、そのフィールド自体の値がNULLなのか、ROLLUPとCUBEによって生成されているのかをどのように区別しますか?
この場合、GROUPING(groupingfield)で解決でき、カラムの値が事実データから来た場合、GROUPING関数は0を返します.カラムの値が、ROLLUPまたはCUBE操作によって生成されたNULLの場合は、1を返します.
eg:
Ref:http://blog.csdn.net/hufengwen/archive/2007/06/19/1657432.aspx
テキストリンク:http://blog.csdn.net/t0nsha/article/details/6538826
この場合、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
テキストリンク:http://blog.csdn.net/t0nsha/article/details/6538826