oracle分割字符串后以单列多行展示
来源:互联网 发布:windows pe img镜像 编辑:程序博客网 时间:2024/05/29 13:29
- 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是递增的,所以会变成七行数据。
分析完毕。
0 0
- oracle分割字符串后以单列多行展示
- oracle分割字符串后以单列多行展示
- 拆分以分隔符分割的单列为多列(行拆分)
- oracle,分组后,字符串以“,”合并
- mysql,oracle合并单列多行记录
- C# 以字符串分割
- java字符串以|分割
- oracle查询一列数据,合并成字符串,以,分割
- MYSQL 分享:最快速度将字符串进行分割以表的方式进行展示
- oracle 连接单列结果集的所有数据。即:单列多行串联
- oracle 连接单列结果集的所有数据(单列多行串联)
- 字符串以指定符号分割
- Java 以空格分割字符串
- 以任意字符分割字符串
- 正则表达式 以 +-*/ 分割字符串
- 在oracle 对有效的字符串分割,后并获得每个分割的字符
- oracle 两个字符串根据指定分割符分割后比较方法
- oracle 分割字符串
- Python中的getattr()函数详解
- 使用appium进行图案解锁
- vs2012 error c4996: This function or variable may be unsafe
- 常用服务器软件nginx、jvm、centOS网络环境等配置
- 什么是同步IO和异步IO
- oracle分割字符串后以单列多行展示
- [点点搬家]初试mod_perl+apache
- Xmanager Enterprise 4-Xftp和xSHELL乱码的问题
- 修改字符串
- mysql中utf8编码中文字符长度问题
- 黑马程序员-Thread-生产者消费者
- delete与delete[]的区别
- 更新物料批次到期日
- Java线程的5种状态及切换(透彻讲解)