ホームページ >データベース >mysql チュートリアル >Oracle SQLでデータを行から列にピボットする方法

Oracle SQLでデータを行から列にピボットする方法

Patricia Arquette
Patricia Arquetteオリジナル
2025-01-23 07:31:10315ブラウズ

How to Pivot Data from Rows to Columns in Oracle SQL?

Oracle SQL でのピボット クエリの作成

Oracle SQL では、データの垂直方向を水平方向に変換するためにピボット クエリが使用されます。一般的なシナリオは、行構成データを列表示形式に変換することです。

「MONTH」列と「VALUE」列を含むデータ テーブルについて考えます。

MONTH VALUE
1 100
2 200
3 300
4 400
5 500
6 600

期待される結果

期待される結果は、対応する「VALUE」を示す各一意の月の列を含むピボット テーブルです。

MONTH_JAN MONTH_FEB MONTH_MAR MONTH_APR MONTH_MAY MONTH_JUN
100 200 300 400 500 600

Oracle 11g 以降

Oracle 11g 以降では、PIVOT 演算子を使用できます。

<code class="language-sql">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)
);</code>

このクエリは必要なピボット テーブルを作成します。

以上がOracle SQLでデータを行から列にピボットする方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。