亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

Oracle SQL樞軸查詢

Oracle SQL樞軸查詢

慕雪6442864 2019-07-04 17:40:37
Oracle SQL樞軸查詢我有如下表所示的數據:MONTH VALUE1     1002     2003     3004     4005     5006     600我想編寫一個SQL查詢,以便給出結果如下:MONTH_JAN MONTH_FEB MONTH_MAR MONTH_APR MONTH_MAY MONTH_JUN100       200       300       400       500       600
查看完整描述

2 回答

?
白衣染霜花

TA貢獻1796條經驗 獲得超10個贊

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支點(和UNPIVOT)語法,但Oracle直到11g才支持它。在9i之前,您必須用Oracle特定的解碼替換case語句。


查看完整回答
反對 回復 2019-07-04
?
月關寶盒

TA貢獻1772條經驗 獲得超5個贊

Oracle 11g及以上

從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_pivotpivot (
   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));


查看完整回答
反對 回復 2019-07-04
  • 2 回答
  • 0 關注
  • 629 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號