oracle切割字符串后以单列多行展示

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了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是递增的,所以会变成七行数据。

分析完成。

 

 

 

 

以上是关于oracle切割字符串后以单列多行展示的主要内容,如果未能解决你的问题,请参考以下文章

Oracle-子查询实例

DataFrame查询2 - 专用查询:索引和切片

用于从 cloudkit 检索单列的代码模式/片段

如何将多列中的字符串添加到R中单列中的多行

Oracle 集合类型

Oracle 集合类型