1. 程式人生 > >Oracle 查詢合並列

Oracle 查詢合並列

.... 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 查詢合並列