web-dev-qa-db-ja.com

OracleSQLピボットクエリ

以下に示すように、テーブルにデータがあります。

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
14
code990

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

2つの列のみをリストします。このようなものは、おそらく年ごとにグループ化する必要があります。

ANSI PIVOT(およびUNPIVOT)構文がありますが、Oracleは11gまでそれをサポートしていませんでした。 9iより前は、CASEステートメントをOracle固有のDECODEに置き換える必要がありました。

15
OMG Ponies

Oracle11g以降

Oracle 11g以降、 PIVOT 演算子を使用して、次の結果を得ることができます。

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)
);
19