首頁 >資料庫 >mysql教程 >如何在 Oracle SQL 中將資料從行轉換為列?

如何在 Oracle SQL 中將資料從行轉換為列?

Patricia Arquette
Patricia Arquette原創
2025-01-23 07:31:10253瀏覽

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中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn