Oracle中REGEXP_SUBSTR及其它支持正則表達式的內置函數小結

Oracle中REGEXP_SUBSTR函數的使用說明:

題目以下:
在oracle中,使用一條語句實現將'17,20,23'拆分紅'17','20','23'的集合。

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

一、查詢使用正則分割後的第一個值,也就是17
[sql]
SELECT REGEXP_SUBSTR('17,20,23','[^,]+',1,1,'i') AS STR FROM DUAL;
結果:
STR
-----
17

二、查詢使用正則分割後的最後一個值,也就是23
[sql]
SELECT REGEXP_SUBSTR('17,20,23','[^,]+',1,3,'i') AS STR FROM DUAL;
結果:
STR
----
23

三、獲取一個多個數值的列,從而可以讓結果以多行的形式展現出來
[sql]
SELECT LEVEL FROM DUAL CONNECT BY LEVEL <=7;
結果:
LEVEL
----
1
2
3
4
5
6
7

四、將上面REGEXP_SUBSTR的occurrence關聯
[sql]
SELECT NVL(REGEXP_SUBSTR('17,20,23', '[^,]+', 1, LEVEL, 'i'), 'NULL') AS STR
FROM DUAL
CONNECT BY LEVEL <= 7;
結果:
STR
----
17
20
23
NULL
NULL
NULL
NULL

五、優化上面的SQL語句,讓生成的行的數量符合實際狀況
[sql]
SELECT REGEXP_SUBSTR('17,20,23', '[^,]+', 1, LEVEL, 'i') AS STR
FROM DUAL
CONNECT BY LEVEL <=
LENGTH('17,20,23') - LENGTH(REGEXP_REPLACE('17,20,23', ',', ''))+1;
結果:
STR
----
17
20
23html

http://www.2cto.com/database/201209/154045.htmlgit

 

Oracle正則表達式(regularexpression)正則表達式

元字符sql

字符含義express

舉例說明緩存

^oracle

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

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

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

-

當使用在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:

開始搜索的位置

 

Oracle支持正則表達式函數舉例。

Regexp_substr:用來提取一個字符串的一部分。

Regexp_substr('first filed, second filed, thirdfiled', [^,]*,')

Pattern爲', [^,]*,'表示以,開始逗號,中間空一個格,連續0或多個非逗號字符,最後仍是逗號,這樣,返回則爲', second filed,'。

-------------------------------------------------------------------------------

Regexp_instr:用來pattern的起始位置。

若有一組地址,返回郵編的位置

regexp_instr('Jone Smith,10045 Berry Lane,SanJoseph,CA

91234-1234','[[:digit:]]{5}([-[[:digit:]]{4}])?$')

顯然結果位置是91234-1234對應的起始位置。

-------------------------------------------------------------------------------

Regexp_replace:用來將pattern替換成須要替換的字符串,相比傳統的replace函數,該函數相比較靈活。例如:

'Jone   smith'中有三個空格,而'Jone  smith'有2個空格,要將中間的空格改成一個空格,使用replace就要使用2次,而是用正則表達式,咱們就就能夠將pattern設計爲

'( ){2,}'這樣

regexp_replace(mc,'( ){2,}',' ')

-------------------------------------------------------------------------------

regexp_like是加強版的like,能夠包含_和%通配符,使用在where條件中。

正則表達式特性---後向引用

經過將自表達式匹配的內容緩存到緩衝區中,從左相右進行編號,以/digit(digit爲1-9)。而子表達式用圓括號表示。

1.在regexp_replace中應用:

將字符串'aa bb cc'反寫成'cc bb aa'則能夠設計以下:

regexp_replace('aa bbcc','(.*) (.*) (.*)','\3 \2 \1')

(.*)則表示任何一個字符串組合,三個這樣的組合用空格隔開,與源字符串吻合,\1,\2,\3則分別存儲了三個字表達式的值,這樣咱們就可使用這個達到目的。

2.在regexp_substr中應用:

查找被空格隔開的重複字母數字值

regexp_substr('the finaltest is is the implention',([[:alnum:]]+)([[:space:]]+)\1')

返回結果爲is is 。([[:alnum:]]+)([[:space:]]+)返回不少字符串,可是增長一個\1就表示連續返回兩個一樣字符串,這樣就把重複的串給找出來。

http://www.jb51.net/article/31227.htm

相關文章
相關標籤/搜索