oracle中有类似split的方法么,Oracle 实现拆分列数据的split()方法
‘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, ‘,‘, ‘‘)) + 1as 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
Oracle 實現拆分列數據的split()方法
標簽:one???connect???實現???--???截取字符串???count()???截取???rownum???nec
本條技術文章來源于互聯網,如果無意侵犯您的權益請點擊此處反饋版權投訴 本文系統來源:http://www.cnblogs.com/jianguang/p/6445156.html
總結
以上是生活随笔為你收集整理的oracle中有类似split的方法么,Oracle 实现拆分列数据的split()方法的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: anaconda使用python写游戏,
- 下一篇: Oracle打开虚拟机闪退,虚拟机上启动