原始的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
abbb
cccc
dddddeed
aconnect 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是遞增的,所以會變成七行資料。
分析完畢。
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 f...
Oracle 分割字串
第一種方式建立函式 create or replace type str split is table of varchar2 4000 create or replace function splitstr p string in varchar2,p delimiter in varchar2 ...
Oracle 字串分割 Split
一 建立陣列型別 sql create orreplace type t ret table is table of varchar2 512 二 建立字串分割函式 sql create orreplace function f split string as str varchar2,as spl...