Oracle11g 分割字符串 REGEXP_SUBSTR

Oracle11g 分割字符串 REGEXP_SUBSTR

  • 例如:有字符串'abc1,cbd2,db3,db5',如何進行分割?

查詢SQL:

SELECT REGEXP_SUBSTR ('abc1,cbd2,db3,db5', '[^,]+', 1,ROWNUM)
FROM DUAL
CONNECT BY ROWNUM <= LENGTH ('abc1,cbd2,db3,db5') - LENGTH (REPLACE ('abc1,cbd2,db3,db5', ',', '')) + 1;

結果:

REGEXP_SUBSTR('ABC1,CBD2,DB3,DB5
--------------------------------
abc1                            
cbd2                            
db3                             
db5                             

已經分割爲4行;

 

  • Oracle函數 REGEXP_SUBSTR 參數
REGEXP_SUBSTR函數格式如下:
function REGEXP_SUBSTR(String, pattern, position, occurrence, modifier)
__srcstr :需要進行正則處理的字符串
__pattern :進行匹配的正則表達式,匹配的值將返回,返回策略由__occurrence決定
__position :起始位置,從第幾個字符開始正則表達式匹配(默認爲1)
__occurrence :標識第幾個匹配組,默認爲1
__modifier :模式('i'不區分大小寫進行檢索,'c'區分大小寫進行檢索。默認爲'c'。)
  • Oracle REGEXP 相關函數

Oracle正則表達式(regularexpression)

元字符

字符含義

舉例說明

^

匹配字符串的開始位置(在[]中使用,此時它表示不接受該字符集合。

^a:匹配以a開始的字符串

[^a]:匹配不含a的字符串

-

當使用在a-m表示範圍;

當使用在第一個字符時表示

連字符串,如[-abc]

 

$

匹配字符結束位置

‘a$':匹配以a結束的字符串

.

匹配除換行符 n之外的任何單字符。

 

?

匹配前面的子表達式零次或一次

tr(y(ing)?):可以表示try或者trying

*

匹配前面的子表達式零次或多次

 

+

匹配前面的子表達式一次或多次

 

()

標記一個子表達式的開始和結束位置

a(b)*可以匹配

ab,abb,abbb,youabb

(c|d)匹配c或d

[]

標記一箇中括號表達式

[cd]匹配選擇c或d等同於

(c|d)。匹配的是單字符,[^cd]是匹配c,d之外的單字符。

[a-z]表示所有小寫字母

{m,n}

m= <出現次數 <=n,'{m}'表示出現m次,'{m,}'表示至少出現m次。

 

|

表示或者的關係。指明兩項之間的一個選擇

 

字符簇

字符含義

 

[[:alpha:]]

任何字母。

 

[[:digit:]]

[[:digit:]] 任何數字。

 

[[:alnum:]]

任何字母和數

 

[[:space:]]

任何白字符。

 

[[:upper:]]

任何大寫字母。

 

[[:lower:]]

任何小寫字母。

 

[[:punct:]]

任何標點符號。

 

[[:xdigit:]]

任何16進制的數字,相當於[0-9a-fA-F]。

 

Oracle支持正則表達式的內置函數

名稱

語法

備註

REGEXP_LIKE

REGEXP_LIKE

(source_string,

pattern

[, match_parameter]

)

source_string:源字符串

Pattern:正則表達式

match_parameter:匹配模式(i:不區分大小寫;c:區分大小寫;n:允許使用可以匹配任意字符串的操作符;m:將x作爲一個包含多行的字符串。

REGEXP_REPLACE

REGEXP_REPLACE

(source_string,

pattern

[,replace_string]

[,position]

[,occurtence]

[,match_parameter]

)

 

replace_string:用於替換的字符串

Position:開始搜索的起始位置

occurtence指定替換第n次出現字符串

其他同上。

REGEXP_SUBSTR

REGEXP_SUBSTR

(source_string, pattern

[,position

[,occurrence

[,match_parameter]]]

)

Position:指定在字符串中準確位置,即開始匹配的字符的位置,默認爲1

Occurrence:指定在源字符串匹配過程中相對其他字符串,哪個字符串應該匹配。例如

select regexp_substr('The zip code80831 is for falcon, co',

'[[:alpha:]]{3,}',

1,

3)

from dual;

結果選擇的是code而非The或zip。

select regexp_substr('The zip code80831 is for falcon, co',

'[[:alpha:]]{3,}',

11,//表示從第11個字符(code的d字符)開始

1)//查找到第一個匹配的就是for了,第二個匹配的是falcon

from dual;

結果是for

REGEXP_INSTR

REGEXP_INSTR

(source_string,

pattern

[,start_position

[,occurrence

[,return_option

[,match_parameter]]]]

)

start_position:

開始搜索位置

Occurrence:

第n次出現pattern,默認爲1

return_option:

0:pattern的起始位置

1:pattern下一個字符起始位置

默認爲0

REGEXP_COUNT

REGEXP_COUNT

(source_string,

pattern

[[,start_position]

[,match_parameter]])

11g新增的函數,表示pattern在原字符串中出現的次數

start_position:

開始搜索的位置

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章