固定列數的行列轉換如
創新互聯2013年至今,是專業互聯網技術服務公司,擁有項目成都網站設計、成都做網站網站策劃,項目實施與項目整合能力。我們以讓每一個夢想脫穎而出為使命,1280元崇陽做網站,已為上家服務,為崇陽各地企業和個人服務,聯系電話:13518219792
student subject grade
---------------------------
student1 語文 80
student1 數學 70
student1 英語 60
student2 語文 90
student2 數學 80
student2 英語 100
轉換為
語文 數學 英語
student1 80 70 60
student2 90 80 100
語句如下:
select student,sum(decode(subject,'語文', grade,null)) "語文",
sum(decode(subject,'數學', grade,null)) "數學",
sum(decode(subject,'英語', grade,null)) "英語"
from table
group by student
2、不定列行列轉換如
c1 c2
--------------
1 我
1 是
1 誰
2 知
2 道
3 不
......
轉換為
1 我是誰
2 知道
3 不
這一類型的轉換必須借助于PL/SQL來完成,這里給一個例子
CREATE OR REPLACE FUNCTION get_c2(tmp_c1 NUMBER)
RETURN VARCHAR2
IS
--用于返回值
Col_c2 VARCHAR2(4000);
BEGIN
FOR cur IN (SELECT c2 FROM t WHERE c1=tmp_c1) LOOP
Col_c2 := Col_c2||cur.c2;
END LOOP;
Col_c2 := rtrim(Col_c2,1);
RETURN Col_c2;
如果你要做轉換查詢,真心勸你不要這么干,我的寫法很麻煩,一張表不停的查詢,邏輯讀肯定搞得要死。
如果是往下面這張表灌數,那么可以寫循環,慢慢來一行對應一列,可以根據表的列和數據的對應關系往里面灌,這個相對簡單些。
我的寫法大概是子查詢+union all 上面為a表
那么就寫為select ‘第一季度' 銷售額,(select 第一季度銷售額 from a where 產品名稱='奶酪')奶酪,(select 第一季度銷售額 from a where 產品名稱='啤酒') from dual
union all
還像上面那么寫,寫第二季度
union all
第三季度
union all
第四季度
一張表重讀查詢8次,如果表很大,我估計機器會宕掉的。
因為單獨從一列來看也可以理解為列轉行,所以用case when寫也可以,這么寫似乎讀取的次數會少些,不過要用到group by分組,天知道二者最后誰的消耗大。不過如果表很大的話,還是那句話,建議新建表然后灌數,這么直接查,真的會死掉的。
以上為個人建議,如果找到什么好寫法,也可以研究下。
方法一:最好理解
select?t.指標名
,sum(decode(t.工廠,'一廠',t.指標值,0))?一廠
,sum(decode(t.工廠,'二廠',t.指標值,0))?二廠
from?數據表?t
group?by?t.指標名
方法二:用oracle11g新特性Pivot,也很好理解
select?指標名,"一廠","二廠"
from?數據表?t
pivot?(sum(t.指標值)?for?"工廠"?in?('一廠'?as?"一廠",'二廠'?as?"二廠"))
文章名稱:oracle如何轉換行列,oracle中行轉列
當前網址:http://vcdvsql.cn/article10/heccgo.html
成都網站建設公司_創新互聯,為您提供微信小程序、網站營銷、Google、服務器托管、網站收錄、動態網站
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯