oracle切割字符串后以单列多行展示
2016-02-07 15:59
459 查看
原始的sql:
查询结果例如以下:
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是递增的,所以会变成七行数据。
分析完成。
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 services
- linux oracle设置环境变量
- Linux系统启动和关闭oracle数据库
- 【转】关于 Oracle 数据库 PSU/SPU/Bundle Patch的补丁号变化
- Oracle热快-从认识到定位
- oracle rman异机恢复
- Oracle 安装报错 [INS-06101] IP address of localhost could not be determined
- oracle数据字典详解
- ORACLE 还有BLOB及CLOB等类型字段的表的导出导入
- Oracle decode和case的区别
- Oracle trunc和round的区别
- ORACLE中dual用法详解
- Entity Framework6 with Oracle(可实现code first)
- Oracle BIEE 相关文章收集
- Oracle 获取本周、本月、本季、本年的第一天和最后一天
- oracle job 定时执行 存储过程
- oracle job的建立及执行
- oracle 11g表空间使用率统计心得
- oracle 11g 卸载
- oracle数据库分页查询