oracle分割字串後以單列多行展示,oracle多行

來源:互聯網
上載者:User

oracle分割字串後以單列多行展示,oracle多行

原始的sql:

select substr(field1,              instr(field1, '|', 1, rownum) + 1,              instr(field1, '|', 1, rownum + 1) -              instr(field1, '|', 1, rownum) - 1) as field2  from (select '|' || 'a|bbb|cccc|ddddd|ee|d|a' || '|' as field1 from dual)connect by instr(field1, '|', 2, rownum) > 0;

查詢結果如下:

field2

a
bbb
cccc
ddddd
ee
d
a

connect by :遞迴,即查詢繼續的條件

instr(field1, '|', 2, rownum)  字串從第2個位置開始,即從a開始,‘|’分隔字元從第一次到第八次出現的位置依次是:3、5、7、9、11、13、15、0,所以會查詢七次,也就是會有七行。

substr函數的第二個參數為instr(field1, '|', 1, rownum) + 1,表示‘|’從第一個位置開始匹配,第一到第七次匹配的位置加上一,即2、4、6、8、10、12、14

substr函數的第三個參數仔細看一下,恒等於一。

也就是說,按‘|’分割後,第一次取第二部分,第二次取第四部分,依次類推。

取的值分別為:a、bbb、cccc、ddddd、ee、d、a

因為rownum是遞增的,所以會變成七行資料。

分析完畢。

 

 

 

 

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.