bl双性强迫侵犯h_国产在线观看人成激情视频_蜜芽188_被诱拐的少孩全彩啪啪漫画

oracle如何轉換行列,oracle中行轉列

怎樣將oracle中的列變成行

固定列數的行列轉換如

創新互聯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;

oracle 行和列轉換

如果你要做轉換查詢,真心勸你不要這么干,我的寫法很麻煩,一張表不停的查詢,邏輯讀肯定搞得要死。

如果是往下面這張表灌數,那么可以寫循環,慢慢來一行對應一列,可以根據表的列和數據的對應關系往里面灌,這個相對簡單些。

我的寫法大概是子查詢+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分組,天知道二者最后誰的消耗大。不過如果表很大的話,還是那句話,建議新建表然后灌數,這么直接查,真的會死掉的。

以上為個人建議,如果找到什么好寫法,也可以研究下。

oracle 行列轉換問題

方法一:最好理解

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。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯

成都定制網站建設