Oracle SQL 피벗 쿼리
아래와 같이 표에 데이터가 있습니다.
MONTH VALUE
1 100
2 200
3 300
4 400
5 500
6 600
아래와 같은 결과가 나올 수 있도록 SQL 쿼리를 작성하고 싶습니다.
MONTH_JAN MONTH_FEB MONTH_MAR MONTH_APR MONTH_MAY MONTH_JUN
100 200 300 400 500 600
Oracle 11g 이상
Oracle 11g부터 연산자를 사용하여 다음과 같은 결과를 얻을 수 있습니다.
create table tq84_pivot (
month number,
value number
);
insert into tq84_pivot values(1, 100);
insert into tq84_pivot values(2, 200);
insert into tq84_pivot values(3, 300);
insert into tq84_pivot values(4, 400);
insert into tq84_pivot values(5, 500);
insert into tq84_pivot values(6, 600);
--
insert into tq84_pivot values(1, 400);
insert into tq84_pivot values(2, 350);
insert into tq84_pivot values(4, 150);
select
*
from
tq84_pivot
pivot (
sum (value) as sum_value for
(month) in (1 as month_jan,
2 as month_feb,
3 as month_mar,
4 as month_apr,
5 as month_mai,
6 as month_jun,
7 as month_jul,
8 as month_aug,
9 as month_sep,
10 as month_oct,
11 as month_nov,
12 as month_dec)
);
Oracle 9i+는 다음을 지원합니다.
SELECT SUM(CASE WHEN t.month = 1 THEN t.value ELSE 0 END) AS JAN,
SUM(CASE WHEN t.month = 2 THEN t.value ELSE 0 END) AS FEB,
SUM(CASE WHEN t.month = 3 THEN t.value ELSE 0 END) AS MAR,
SUM(CASE WHEN t.month = 4 THEN t.value ELSE 0 END) AS APR,
SUM(CASE WHEN t.month = 5 THEN t.value ELSE 0 END) AS MAY,
SUM(CASE WHEN t.month = 6 THEN t.value ELSE 0 END) AS JUN
FROM YOUR_TABLE t
두 개의 열만 나열합니다. 이와 같은 열은 연도별로 그룹화되어야 합니다.
ANSI PIBOT(및 UNPIBOT) 구문이 있지만 Oracle은 11g까지 지원하지 않았습니다.9i 이전에는 CASE 문을 Oracle 전용 DECODE로 교체해야 했습니다.
Oracle 11g+용 동적 피벗
Oracle SQL에서 동적 피벗을 위한 간단한 방법은 없습니다. 그렇지 않으면XML
유형 결과
를 위해non-XML
결과 PL/SQL은 다음 함수를 생성하여 사용할 수 있습니다.SYS_REFCURSOR
반품 타입
피벗 절 포함
CREATE OR REPLACE FUNCTION Get_Month_Values RETURN SYS_REFCURSOR IS v_recordset SYS_REFCURSOR; v_sql VARCHAR2(32767); v_cols VARCHAR2(32767); BEGIN SELECT LISTAGG( ''''||month||''' AS "MONTH_'||TO_CHAR( TO_DATE(month,'mm') ,'MON')||'"' , ',' ) WITHIN GROUP ( ORDER BY month ) INTO v_cols FROM tab; v_sql :='SELECT * FROM tab t PIVOT ( MAX(value) FOR month IN ( '|| v_cols ||' ) )'; OPEN v_recordset FOR v_sql; DBMS_OUTPUT.PUT_LINE(v_sql); RETURN v_recordset; END; /
조건부 집계 포함
CREATE OR REPLACE FUNCTION Get_Month_Values RETURN SYS_REFCURSOR IS v_recordset SYS_REFCURSOR; v_sql VARCHAR2(32767); v_cols VARCHAR2(32767); BEGIN SELECT LISTAGG('MAX( CASE WHEN month = '''||month||''' THEN '||value||' END ) AS "MONTH_'||TO_CHAR( TO_DATE(month,'mm') ,'MON')||'"' , ',' ) WITHIN GROUP ( ORDER BY month ) INTO v_cols FROM tab; v_sql :='SELECT '|| v_cols ||' FROM tab'; OPEN v_recordset FOR v_sql; DBMS_OUTPUT.PUT_LINE(v_sql); RETURN v_recordset; END; /
그런 다음 함수를 호출할 수 있습니다.
VAR rc REFCURSOR
EXEC :rc := Get_Month_Values;
PRINT rc
SQL Developer's 명령줄에서
테이블의 피벗을 얻는 방법
SELECT *
FROM Product
PIVOT (MAX(VALUE) FOR (P_name, P_id) IN ((choclate,6) AS choclate_6, (candies,8) AS candies_8, (Biscuits,9) AS Biscuits_9)
언급URL : https://stackoverflow.com/questions/4841718/oracle-sql-pivot-query
'programing' 카테고리의 다른 글
"Mongo 오류:객체에서 지리적 키를 추출할 수 없음"(유형: 점) (0) | 2023.06.28 |
---|---|
내가 하는 일은 커밋을 지우는 것뿐인데 git-rebase에서 병합 충돌이 발생하는 이유는 무엇입니까? (0) | 2023.06.28 |
Android 6.0(Mashmallow)에서 특정 앱에 대한 권한 화면을 프로그래밍 방식으로 열려면 어떻게 해야 합니까? (0) | 2023.06.28 |
동일한 그래프에서 ggplot2를 사용하여 두 변수를 선으로 표시 (0) | 2023.06.28 |
각 사용자를 Firebase의 데이터에 연결하려면 어떻게 해야 합니까? (0) | 2023.06.23 |