假設存在如下縱向表,第一列為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;
?
?
?
?
更多文章、技術交流、商務合作、聯系博主
微信掃碼或搜索:z360901061

微信掃一掃加我為好友
QQ號聯系: 360901061
您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對您有幫助就好】元
