Oracle 查詢合並列
阿新 • • 發佈:2017-07-30
.... col arp font 例如 archive spa www strong
在ORACLE 查詢時,有時要將多個列合並成一行,其方法如下:
1. decode 函數
decode 函數的語法為:
decode(條件,值1,返回值1,值2,返回值2,...值n,返回值n,缺省值)
或 decode(條件,值1,返回值1,返回值2,...值n,返回值n,缺省值)
其定義如下::
IF 條件=值1 THEN RETURN(翻譯值1) ELSIF 條件=值2 THEN RETURN(翻譯值2) ...... ELSIF 條件=值n THEN RETURN(翻譯值n) ELSE RETURN(缺省值) END IF
例如:decode(字段或字段的運算,值1,值2,值3)
這個函數運行的結果是,當字段或字段的運算的值等於值1時,該函數返回值2,否則返回值3
當然值1,值2,值3也可以是表達式,這個函數使得某些sql語句簡單了許多
2. wmsys.wm_concat 函數
把某一列合並,其語法為: wm_concat(列名)
把合並後的逗號(默認)換成其它的符號,比如|號 , replace(wm_concat(列名),‘,‘,‘|‘)
3. || 連接符號
語法為: select col1,col2||‘【‘ || col3|| ‘】‘ as A , col4 from table1 其中 ‘【’ 是自行加入的符號,可根據 需要進行替換
4. 自定義sql 語句
SELECT n_sec_code, TRANSLATE (LTRIM (text, ‘/‘), ‘*/‘, ‘*,‘) researcherList FROM (SELECT ROW_NUMBER () OVER (PARTITION BY n_sec_code ORDER BY n_sec_code, lvl DESC) rn, n_sec_code, text FROM (SELECT n_sec_code, LEVEL lvl, SYS_CONNECT_BY_PATH (c_researcher_code,‘/‘) text FROM (SELECT n_sec_code, c_researcher_code as c_researcher_code, ROW_NUMBER () OVER (PARTITION BY n_sec_code ORDER BY n_sec_code,c_researcher_code) x FROM m_researcher_stock_rel ORDER BY n_sec_code, c_researcher_code) a CONNECT BY n_sec_code = PRIOR n_sec_code AND x - 1 = PRIOR x)) WHERE rn = 1 ORDER BY n_sec_code;
只需要把SQL中“n_sec_code” 換為你的用來匯總的列,“c_researcher_code”替換為需合並文本的列,“m_researcher_stock_rel”替換為你的表名
參考文章:
http://www.cnblogs.com/heekui/archive/2009/07/30/1535516.html
http://blog.csdn.net/catoop/article/details/8124561
Oracle 查詢合並列