主页 > 知识库 > Oracle逗号分隔列转行实现方法

Oracle逗号分隔列转行实现方法

热门标签:Linux服务器 呼叫中心市场需求 铁路电话系统 AI电销 百度竞价排名 地方门户网站 网站排名优化 服务外包
那么,现在如果给出一个权限编号,要去检索出用后这个权限的用户集合,就会需要在逗号分隔的多个权限编号中去匹配给出的这个权限编号。如果使用like去做,一则效率不高,二则匹配不精确。因此用到了逗号分隔列转行的方法。目前该方法只适合在oracle数据库中使用。该方法只需要sql语句就可以实现列转行。

  下面给出该方法的示例:

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实现行转换成列的方法

标签:湖南 黄山 衡水 崇左 仙桃 湘潭 兰州 铜川

巨人网络通讯声明:本文标题《Oracle逗号分隔列转行实现方法》,本文关键词  ;如发现本文内容存在版权问题,烦请提供相关信息告之我们,我们将及时沟通与处理。本站内容系统采集于网络,涉及言论、版权与本站无关。
  • 相关文章
  • 收缩
    • 微信客服
    • 微信二维码
    • 电话咨询

    • 400-1100-266