Oracle 实现拆分列数据的split()方法

-- 创建需要划分的字符串
with T1 as(
   select ‘one,two,three,four,five,six,seven,eight,nine,zero‘ as source_string
     from dual),  

-- 统计字符串中子串的个数,用 ‘,‘ 来划分子串
T2 as(
   select regexp_count(source_string, ‘[^,]+‘) as source_substring_count
     from T1),  

-- 根据子串的个数创建索引列,用于给T4的regexp_substr()方法索引
T3 as(
   select rownum as row_number
     from dual, T2
   connect by rownum <= T2.source_substring_count),  

-- 根据每个索引值逐个截取字符串
T4 as(
   select T3.row_number as substring_index,
          regexp_substr(T1.source_string, ‘[^,]+‘, 1, T3.row_number) as substring
     from T1, T3)  

select substring_index, substring from T4;

鉴于 regexp_count() 方法是 Oracle 11g 才新加上的,之前的版本并没有,这里再用另一种方法来统计子串的个数:

-- 创建需要划分的字符串
with T1 as(
   select ‘one,two,three,four,five,six,seven,eight,nine,zero‘ as source_string
     from dual),  

-- 统计字符串中子串的个数
-- 字符串中‘,‘字符用‘‘代替后,其减少的长度自然就是原串中‘,‘字符的个数
T2 as(
   select length(T1.source_string) - length(replace(T1.source_string, ‘,‘, ‘‘)) + 1
          as source_substring_count
     from T1),  

-- 根据子串的个数创建索引列,用于给T4的regexp_substr()方法索引
T3 as(
   select rownum as row_number
     from dual, T2
   connect by rownum <= T2.source_substring_count),  

-- 根据每个索引值逐个截取字符串
T4 as(
   select T3.row_number as substring_index,
          regexp_substr(T1.source_string, ‘[^,]+‘, 1, T3.row_number) as substring
     from T1, T3)  

select substring_index, substring from T4;  

看见的一个博主写的,正好自己能用,先记下,同时感谢这位博主

原链接:http://flforever1213.iteye.com/blog/1026096

时间: 2024-08-24 13:45:57

Oracle 实现拆分列数据的split()方法的相关文章

Oracle 闪回 找回数据的实现方法

Oracle 闪回 找回数据的实现方法 闪回技术是Oracle强大数据库备份恢复机制的一部分,在数据库发生逻辑错误的时候,闪回技术能提供快速且最小损失的恢复.这篇文章主要介绍了Oracle 闪回 找回数据的实现方法,需要的朋友可以参考下 闪回技术是Oracle强大数据库备份恢复机制的一部分,在数据库发生逻辑错误的时候,闪回技术能提供快速且最小损失的恢复(多数闪回功能都能在数据库联机状态下完成).需要注意的是,闪回技术旨在快速恢复逻辑错误,对于物理损坏或是介质丢失的错误,闪回技术就回天乏术了,还是

Oracle导出数据结构和数据表的方法

1.PLSQL导出数据结构(数据表.序列.触发器.函数.视图) 1)在左侧 点击tables 2)Tools-->Export User Objects 3)红色1 是你要选择导出的表,红色2 是你要导出到.sql文件 存放到自己电脑位置,红色三就是导出的意思,做完这一步就已经把数据表的结构导出来了 2.PLSQL导出表数据 1)在左侧 点击tables,然后 Tools-->Exports Tables 2)注意红色的部分,导出文件后缀为.sql

Oracle GoldenGate从oracle db 到非oracle db的初始化数据同步的方法

非oracle db以 sqlserver为样例说明: 我的思路 A :oracle db 生产 B: oracle db 中间机 C: sqlserver db 目的端 A-> B->C 注意:B上既有rep进程也有ext进程,此时.C上也须要建立针对B的rep进程. A->B能够完毕 在线的完毕初始化同步(基于scn号的expdp) A->B的初始化做完之后,stop 掉 B的rep进程,此时B库为静态数据库,此时进行B->C的同步(使用etl工具 or sqlserve

Hibernate中HQLwhere用法和单独取出几列数据的读取方法

String hql = "select thedate,thehour,node,query_num from Cdns cdns where thehour = " +"21"; Query query = session.createQuery(hql); List<Object[]> list = query.list(); for(Object[] object : list){ System.out.println((String)objec

Python pandas 数据框的str列内置的方法详解

原文链接:http://www.datastudy.cc/to/31 在使用pandas框架的DataFrame的过程中,如果需要处理一些字符串的特性,例如判断某列是否包含一些关键字,某列的字符长度是否小于3等等这种需求,如果掌握str列内置的方法,处理起来会方便很多. 下面我们来详细了解一下,Series类的str自带的方法有哪些. 1.cat() 拼接字符串 例子: >>> Series(['a', 'b', 'c']).str.cat(['A', 'B', 'C'], sep=',

sqlserver字符串拆分(split)方法汇总

--方法0:动态SQL法 declare @s varchar(100),@sql varchar(1000) set @s='1,2,3,4,5,6,7,8,9,10' set @sql='select col='''+ replace(@s,',',''' union all select ''')+'''' PRINT @sql exec (@sql) --方法1:循环截取法 if exists (select * from dbo.sysobjects where id = object

Oracle中对列加密的方法

Oracle中对列加密的方法 2011-12-22 17:21:13 分类: Linux Oracle支持多种列加密方式: 1,透明数据加密(TDE):create table encrypt_col(id int,txt varchar2(100) encrypt using '算法名称' identified by '密钥' no salt);优点:对应用完全透明缺点:需要数据库管理员管理wallet,增加了管理复杂性,也无法避免数据库管理员查看原文. 2,使用DBMS_CRYPTO包优点:

转-oracle中比较两表表结构差异和数据差异的方法

oracle中比较两表表结构差异和数据差异的方法 原作者:li2008xue2008ling 出处:http://blog.csdn.net 在工作中需要完成这么一个需求:比较两个表的表结构是否形相同,并找出差异.比较两个表中的数据是否相同,并找出差异数据? 分析:由于表结构中字段比较多,手工比较很浪费时间,而且不能保证不出错误.对于表中的数据那就能多了,更不能靠这种方式比较. 为了思考问题简单和方便测试,首先先建立两个测试表,并插入一些测试数据吧,sql如下: create table t_A

python pandas 获取列数据的几种方法及书写形式比较

pandas获取列数据位常用功能,但在写法上还有些要注意的地方,在这里总结一下: ''' author: zilu.tang 2015-12-31 ''' import pandas as pd data1 = pd.DataFrame(...) #任意初始化一个列数为3的DataFrame data1.columns=['a', 'b', 'c'] 1. data1['b'] #这里取到第2列(即b列)的值 2. data1.b #效果同1,取第2列(即b列) #这里b为列名称,但必须是连续字