下面给出该方法的示例:
select a,b,c from
(with test as (select ‘aaa’ a,’bbb’ b,’1,2,3′ c from dual)
select a,b,substr(t.ca,instr(t.ca, ‘,’, 1, c.lv) + 1,instr(t.ca, ‘,’, 1, c.lv + 1) – (instr(t.ca, ‘,’, 1, c.lv) + 1)) AS c
from (select a,b,’,’ || c || ‘,’ AS ca,length(c || ‘,’) – nvl(length(REPLACE(c, ‘,’)), 0) AS cnt FROM test) t,
(select LEVEL lv from dual CONNECT BY LEVEL <= 100) c where c.lv <= t.cnt )
执行以上代码,结果如下图:

模拟数据列 c 中的内容“1,2,3”被转成了三行,前面两列的内容同时附带过去。在实际运用时,只要把
select ‘aaa’ a,’bbb’ b,’1,2,3′ c from dual 替换成实际需要转换的数据表中的字段即可,其中c字段必须是要进行转换的保存逗号分隔内容的字段。下面的内容都可以不需要更改。其中“LEVEL <= 100”中的数字100代表匹配字段内容中出现逗号的次数,可以自行更改。
您可能感兴趣的文章:
- Oracle实现行列转换的方法分析
- Oracle的数据表中行转列与列转行的操作实例讲解
- Oracle 数据库针对表主键列并发导致行级锁简单演示
- oracle wm_concat 列转行 逗号分隔
- 从Oracle 表格行列转置说起
- Oracle CBO几种基本的查询转换详解
- oracle中to_date详细用法示例(oracle日期格式转换)
- 通过创建SQLServer 2005到 Oracle10g 的链接服务器实现异构数据库数据转换方案
- MySQL转换Oracle的需要注意的七个事项
- 将mysql转换到oracle必须了解的50件事
- ORACLE常用数值函数、转换函数、字符串函数
- Oracle实现行转换成列的方法
声明:本站(华域联盟www.cnhackhy.com)所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。

评论(0)