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

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

Sql代码  
  1. -- 创建需要划分的字符串  
  2. with T1 as(  
  3.    select 'one,two,three,four,five,six,seven,eight,nine,zero' as source_string  
  4.      from dual),  
  5.      
  6. -- 统计字符串中子串的个数,用 ',' 来划分子串  
  7. T2 as(  
  8.    select regexp_count(source_string, '[^,]+'as source_substring_count  
  9.      from T1),  
  10.      
  11. -- 根据子串的个数创建索引列,用于给T4的regexp_substr()方法索引  
  12. T3 as(  
  13.    select rownum as row_number  
  14.      from dual, T2  
  15.    connect by rownum <= T2.source_substring_count),  
  16.      
  17. -- 根据每个索引值逐个截取字符串  
  18. T4 as(  
  19.    select T3.row_number as substring_index,  
  20.           regexp_substr(T1.source_string, '[^,]+', 1, T3.row_number) as substring  
  21.      from T1, T3)  
  22.      
  23. select substring_index, substring from T4;  
 
鉴于 regexp_count() 方法是 Oracle 11g 才新加上的,之前的版本并没有,这里再用另一种方法来统计子串的个数:
Sql代码  
  1. -- 创建需要划分的字符串  
  2. with T1 as(  
  3.    select 'one,two,three,four,five,six,seven,eight,nine,zero' as source_string  
  4.      from dual),  
  5.      
  6. -- 统计字符串中子串的个数  
  7. -- 字符串中','字符用''代替后,其减少的长度自然就是原串中','字符的个数  
  8. T2 as(  
  9.    select length(T1.source_string) - length(replace(T1.source_string, ',''')) + 1  
  10.           as source_substring_count  
  11.      from T1),  
  12.      
  13. -- 根据子串的个数创建索引列,用于给T4的regexp_substr()方法索引  
  14. T3 as(  
  15.    select rownum as row_number  
  16.      from dual, T2  
  17.    connect by rownum <= T2.source_substring_count),  
  18.      
  19. -- 根据每个索引值逐个截取字符串  
  20. T4 as(  
  21.    select T3.row_number as substring_index,  
  22.           regexp_substr(T1.source_string, '[^,]+', 1, T3.row_number) as substring  
  23.      from T1, T3)  
  24.      
  25. select substring_index, substring from T4;  
 
运行结果:
运行结果:



你可能感兴趣的:(oralce行列变换)