原始的sql:sql
select substr(field1,
函数
instr(field1, '|', 1, rownum) + 1,
code
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)
select
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是递增的,因此会变成七行数据。
分析完毕。