• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • MsSql
  • Mysql
  • oracle
  • MariaDB
  • DB2
  • SQLite
  • PostgreSQL
  • MongoDB
  • Redis
  • Access
  • 数据库其它
  • sybase
  • HBase
您的位置:首页 > 数据库 >oracle > Oracle逗号分隔列转行实现方法

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

作者: 字体:[增加 减小] 来源:互联网 时间:2017-05-11

通过本文主要向大家介绍了oracle 逗号分隔,oracle 逗号连接,oracle 缺失逗号,逗号分隔值文件转换,逗号分隔值文件等相关知识,希望本文的分享对您有所帮助
那么,现在如果给出一个权限编号,要去检索出用后这个权限的用户集合,就会需要在逗号分隔的多个权限编号中去匹配给出的这个权限编号。如果使用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代表匹配字段内容中出现逗号的次数,可以自行更改。

</div>
分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

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

相关文章

  • 2017-05-11利用windows任务计划实现oracle的定期备份
  • 2017-05-11数据库查询排序使用随机排序结果示例(Oracle/MySQL/MS SQL Server)
  • 2017-05-11oracle 11g导出数据时报ORA 1455错误的处理方法
  • 2017-05-11Oracle删除重复的数据,Oracle数据去重复
  • 2017-05-11Oracle 数据显示 横表转纵表
  • 2017-05-11win7 64位操作系统中Oracle 11g + plsql安装教程详解(图解)
  • 2017-05-11oracle 索引的相关介绍(创建、简介、技巧、怎样查看) .
  • 2017-05-11Oracle高级队列(Advanced Queue)简单实例
  • 2017-05-11直接拷贝数据文件实现Oracle数据迁移
  • 2017-05-11Oracle 插入超4000字节的CLOB字段的处理方法

文章分类

  • MsSql
  • Mysql
  • oracle
  • MariaDB
  • DB2
  • SQLite
  • PostgreSQL
  • MongoDB
  • Redis
  • Access
  • 数据库其它
  • sybase
  • HBase

最近更新的内容

    • plsql与tsql的语法不同
    • Redhat 6.2 下 oracle 11g R2的安装详解第1/2页
    • Oracle 高速批量数据加载工具sql*loader使用说明
    • Linux下的Oracle启动脚本及其开机自启动
    • 关于Oracle listener日志解析利器的使用方法
    • oracle10g 数据备份与导入
    • oracle里IW和WW 区别
    • Oracle数据库设置任务计划备份一周的备份记录
    • Oracle回滚段的概念,用法和规划及问题的解决
    • oracle 层次化查询(行政区划三级级联)

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有