1. 程式人生 > >ORACLE縱向錶轉換為橫向表寫法

ORACLE縱向錶轉換為橫向表寫法

假設存在如下縱向表,第一列為id(可能是某個業務資料的id),第二列為型別,第三列為型別對應的值,如下圖:

如上表,存在2,3,4三種類型,其中業務資料ID為1的三種類型都有值,業務資料ID為2的三種類型都有值,業務資料ID為3的只有型別2和3有值,現在要把縱向表橫過來顯示,可以採用如下程式碼:

 -- =========================================================
-- 縱向表變橫向表:
-- 1. 轉換型別,型別的值必須是整數,且不等於0,即0沒有意義,0可以表示為空
 -- =========================================================
SELECT 
       t.id,
       SUM(DECODE(t.code, 2, 2, 0)) "第二項", -- 如果該行型別為2則就是2,其它的都為0
       SUM(DECODE(t.code, 3, 3, 0)) "第三項",
       SUM(decode(t.code, 4, 4, 0)) "第四項"
 FROM ttt t WHERE t.id=1 GROUP BY t.id;
 -- =========================================================
-- 縱向表變橫向表:
-- 1. 轉換型別對應的資料,且資料需要是數值,且0沒有意義,即0可以表示為空
 -- =========================================================
 SELECT 
       t.id,
       SUM(DECODE(t.code, 2, t.val, 0)) "第二項", -- 如果該行型別為2則顯示2型別對應的值DECODE,否則都顯示0
       SUM(DECODE(t.code, 3, t.val, 0)) "第三項",
       SUM(DECODE(t.code, 4, t.val, 0)) "第四項"
 FROM ttt t GROUP BY t.id;