Oracle 查詢合並列


在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

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM