中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

oracle多行轉列怎么實現

小億
83
2024-09-13 13:38:24
欄目: 云計算

在Oracle中,可以使用PIVOT操作將多行數據轉換為單列的多個值

假設有一個名為sales_data的表,其結構如下:

CREATE TABLE sales_data (
  product_id NUMBER,
  month VARCHAR2(10),
  sales_amount NUMBER
);

插入一些示例數據:

INSERT INTO sales_data VALUES (1, 'January', 100);
INSERT INTO sales_data VALUES (1, 'February', 200);
INSERT INTO sales_data VALUES (2, 'January', 150);
INSERT INTO sales_data VALUES (2, 'February', 250);

要將這些數據轉換為每個產品ID對應一行,每個月對應一列的格式,可以使用以下查詢:

SELECT * FROM (
  SELECT product_id, month, sales_amount
  FROM sales_data
)
PIVOT (
  SUM(sales_amount)
  FOR month IN ('January' AS january, 'February' AS february)
);

查詢結果如下:

PRODUCT_ID JANUARY FEBRUARY
---------- -------- --------
         1       100      200
         2       150      250

在這個例子中,我們首先從sales_data表中選擇product_idmonthsales_amount列。然后,我們使用PIVOT操作將month列的值轉換為列名,并對sales_amount列求和。最后,我們使用FOR子句指定要轉換的月份。

0
阳泉市| 宁晋县| 东海县| 通辽市| 龙井市| 乳山市| 金山区| 泰安市| 长兴县| 柞水县| 卢湾区| 泸定县| 婺源县| 阆中市| 志丹县| 乌拉特前旗| 井冈山市| 信阳市| 康乐县| 海南省| 徐闻县| 赫章县| 临高县| 通城县| 会昌县| 曲周县| 阜新| 枣阳市| 岳西县| 芷江| 兴业县| 丽水市| 阜城县| 桐梓县| 河津市| 巴中市| 九台市| 临清市| 广河县| 资讯| 称多县|