전체/Oracle
ORACLE PIVOT과 UNPIVOT 정리
effortDev
2017. 6. 9. 11:55
PIVOT
열을 행으로 ROW 형태의 데이터를 COLUMN 형태로 보여주는 쿼리이다.
컬럼의 값을 기준으로 새로운 컬럼을 도출하여 다양한 집계함수를 적용 가능하다.
UNPIVOT
행을 열으로 COLUMN 형태를 ROW 형태로 보여주는 쿼리이다.
Pivot 된 결과를 되돌리는 기능이 아닌 순수하게 Pivot 에 대응 되는 개념이다.
Pivot 된 결과를 Unpivot 을 쓴다고 해도 원래의 Pivot 전 테이블로 돌아갈 수 없다.
컬럼을 특정 컬럼의 값으로 대응하여 해당 컬럼의 값은 별도의 컬럼에 표시하여 나열한다.
기능적으로 Pivot 과 반대되는 개념이다.
1 2 3 4 5 6 7 8 9 10 11 12 | -- PIVOT 사용 전 WITH T AS ( SELECT CHR(LEVEL + 64) C , LEVEL V FROM DUAL connect by LEVEL <= 10 ) SELECT C , TO_CHAR(V) V FROM T; | cs |
출력 결과
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 | -- PIVOT 사용 후 WITH T AS ( SELECT CHR(LEVEL + 64) C , LEVEL V FROM DUAL CONNECT BY LEVEL <= 10 ) SELECT * FROM ( SELECT C , V FROM T ) PIVOT ( MIN(C) FOR V IN(1 V1, 2 V2, 3 V3, 4 V4, 5 V5, 6 V6, 7 V7, 8 V8, 9 V9, 10 V10)) | cs |
출력 결과
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 | -- UNPIVOT 사용 후 WITH T AS ( SELECT CHR(LEVEL + 64) C , LEVEL V FROM DUAL connect by LEVEL <= 10 ) SELECT * FROM ( SELECT C , TO_CHAR(V) V FROM T ) UNPIVOT ( V FOR GB2 IN (C AS 1, V AS 2) ) | cs |
출력 결과
1 2 3 4 5 6 7 8 9 10 11 12 | -- PIVOT WITH T AS( SELECT '1월' 월, '홍길동' 성명, 110 급여 FROM DUAL UNION ALL SELECT '1월' 월, '홍길동' 성명, 30 급여 FROM DUAL UNION ALL SELECT '1월' 월, '이상현' 성명, 210 급여 FROM DUAL UNION ALL SELECT '1월' 월, '김성현' 성명, 200 급여 FROM DUAL UNION ALL SELECT '2월' 월, '김성현' 성명, 120 급여 FROM DUAL UNION ALL SELECT '2월' 월, '이상현' 성명, 220 급여 FROM DUAL ) SELECT * FROM T PIVOT ( SUM(급여) FOR 월 IN ('1월','2월')) | cs |
출력 결과
1 2 3 4 5 6 7 | -- UNPIVOT WITH T AS( SELECT '홍길동' 성명, 140 일월, 120 이월 FROM DUAL UNION ALL SELECT '김철수' 성명, 210 일월, 220 이월 FROM DUAL ) SELECT * FROM T UNPIVOT(급여 FOR 월 IN(일월, 이월)) | cs |
출력 결과