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

原始的sql:sql

 
  1. select substr(field1,函數

  2.  
  3. instr(field1, '|', 1, rownum) + 1,code

  4.  
  5. instr(field1, '|', 1, rownum + 1) -遞歸

  6.  
  7. instr(field1, '|', 1, rownum) - 1) as field2字符串

  8.  
  9. from (select '|' || 'a|bbb|cccc|ddddd|ee|d|a' || '|' as field1 from dual)select

  10.  
  11. connect by instr(field1, '|', 2, rownum) > 0;數據

查詢結果以下:查詢

field2co

a
bbb
cccc
ddddd
ee
d
a字符

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

instr(field1, '|', 2, rownum)  字符串從第2個位置開始,即從a開始,‘|’分隔符從第一次到第八次出現的位置依次是:三、五、七、九、十一、1三、1五、0,因此會查詢七次,也就是會有七行。

substr函數的第二個參數爲instr(field1, '|', 1, rownum) + 1,表示‘|’從第一個位置開始匹配,第一到第七次匹配的位置加上一,即二、四、六、八、十、十二、14

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

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

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

由於rownum是遞增的,因此會變成七行數據。

分析完畢。

相關文章
相關標籤/搜索