博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
oracle切割字符串后以单列多行展示
阅读量:6977 次
发布时间:2019-06-27

本文共 698 字,大约阅读时间需要 2 分钟。

原始的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是递增的,所以会变成七行数据。

分析完成。

 

 

 

 

转载地址:http://ffupl.baihongyu.com/

你可能感兴趣的文章
Provisioning Services 7.8 入门系列教程之十三 使用 Boot Device Management(BDM)
查看>>
Centos 6.4下MySQL备份及还原详情介绍
查看>>
sql server 表索引碎片处理
查看>>
ASP网络编程从入门到精通 下载
查看>>
集群概述及原理笔记(1)
查看>>
主动防病毒内容篇
查看>>
无准备,不编程——计算机达人成长之路(15)连载
查看>>
服务器监控--cacti中英文版安装全解
查看>>
Nginx+Tomcat实现反向代理与动静分离
查看>>
WSUS Troubleshooting guide
查看>>
在SQL中使用CRL函数示例
查看>>
ATLAS入门篇之CascadingDropDown控件编程
查看>>
《从零开始学Swift》学习笔记(Day 47)——final关键字
查看>>
linux下磁盘镜像软件DRBD的使用
查看>>
snort源码的详细分析
查看>>
揭开Annotation的面纱
查看>>
使用DPM2007备份还原Exchange2007邮箱数据库
查看>>
zabbix企业应用之监控oracle
查看>>
FOSCommentBundle功能包:设置Doctrine ODM映射
查看>>
[Web 开发] 定制IE下载对话框的按钮(打开/保存)
查看>>