ORACLE縱向錶轉換為橫向表寫法
阿新 • • 發佈:2019-02-09
假設存在如下縱向表,第一列為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;