程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> Oracle數據庫 >> Oracle教程 >> oracle分割字符串後以單列多行展示

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

編輯: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是遞增的,所以會變成七行數據。

分析完畢。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved