Oracle正規表示式函式

2021-06-06 10:07:40 字數 4488 閱讀 8174

oracle正規表示式函式

1、正規表示式中的元字元

元字元

意思

例子

\

說明要匹配的字元是乙個特殊字元、常量或者後者引用。(後引用重複上一次的匹配)

\n 匹配換行符

\\ 匹配 \

\( 匹配 (

\) 匹配 )

^匹配字串的開頭位置

如果a是字串的第乙個字元,^a 匹配 a

$

匹配字串的末尾位置

如果b是字串的最後乙個字元,$b 匹配 b

*

匹配前面的字元0次或多次

ba*rk可以匹配 brk、bark、baark等等

+匹配前面的字元1次或多次

ba+rk可以匹配 bark、baark等等,但是不能匹配brk,也就是說,最少有以一次。

?匹配前面的字元0次或1次

ba?rk可以匹配 bark、brk等等,但是不能匹配baark。

匹配前面的字元恰好是n次,其中n是整數

hobit可以匹配hobbit

匹配前面的字元至少是n次,最多是m次,其中n,m都是整數

hobit可以匹配hobbit或者hobbbit

.匹配除null以外的任意單個字元

hob.it中的.可以是任意的單個字元,如:hobsit等等

(pattern)

括號中pattern是乙個子正規表示式,匹配指定pattern模式的乙個子表示式。

如:aaa(x|y)可以匹配aaax或者aaay。

x|y匹配「或」

x|y可以匹配x或者y

[abc]

可以匹配abc中的任何單個字元

hello[abc]可以匹配helloa,hellob,helloc

[a-z]

可以匹配指定範圍內的任何單個字元

hell[a-z]可以匹配hello或者hellz

[::]

指定乙個字元類,可以匹配該類中的任何字元

[:alphanum:]可以匹配字元0-9、a-z、a-z

[:alpha:]可以匹配字元a-z、a-z

[:blank:]可以匹配空格或tab鍵

[:digit:]可以匹配數字0-9

[:graph:]可以匹配非空字元

[:lower:]可以匹配小寫字母a-z

[:print:]與[:graph:]類似,不同之處在於[:print:]包括空格字元

[:punct:]可以匹配標點符號.,""等等

[:space:]可以匹配所有的空字元

[:upper:]可以匹配大寫字母a-z

[:xdigit:]可以匹配十六進製制數字0-9、a-f、a-f

\n這是對前一次匹配命中的乙個後引用,其中n是乙個正整數

(.)\1可以匹配兩個連續相同的非空字元。(.)可以匹配除null以外的任何單個字元,而\1則重複上一次匹配的內容,即再次匹配相同的字元,因此可以匹配兩個連續相同的非空字元

2、regexp_like(x,pattern[,match_option])用於在x中查詢正規表示式pattern,該函式還可以提供乙個可選的引數match_option字串說明預設的匹配選項。match_option的取值如下:

『c』 說明在進行匹配時區分大小寫(預設值);

'i' 說明在進行匹配時不區分大小寫;

'n' 允許使用可以匹配任意字元的操作符;

'm' 將x作為乙個包含多行的字串。

sql **

declare

v_first_name varchar2(50);

v_dobdate;

begin

--返回1965-1968你出生的first_name以『j』開頭的消費者

selectfirst_name,dobintov_first_name,v_dob

fromcustomers

whereregexp_like(to_char(dob,'yyyy'),'^196[5-8]$') and regexp_like(first_name,'^j');

dbms_output.put_line(v_first_name);

end;

3、regexp_instr(x,pattern[,start[,occurrence[,return_option[, match_option]]]])用於在x中查詢pattern。返回pattern在x中出現的位置。匹配位置從1開始。可以參考字串函式 instr(),引數相關:

'start' 開始查詢的位置;

'occurrence' 說明應該返回第幾次出現pattern的位置;

'eturn_option' 說明應該返回什麼整數。若該引數為0,則說明要返回的整數是x中的乙個字元的位置;若該引數為非0的整數,則說明要返回的整數為x中出現在pattern之後的字元的位置;

'match_option' 修改預設的匹配設定。

sql **

declare

v_resultinteger;

begin

--返回17,找出l開頭的 後跟4個任意字母的單詞在第乙個引數中第一次出現的位置,這裡是light中l的位置

selectregexp_instr('but, soft! what light through yonder window breaks?','l[[:alpha:]]',1,1,0)intov_result

fromdual;

dbms_output.put_line(v_result);

--返回22,找出l開頭的 後跟4個任意字母的單詞在第乙個引數中第一次出現的位置,這裡是light中t的位置+1

selectregexp_instr('but, soft! what light through yonder window breaks?','l[[:alpha:]]',1,1,1)intov_result

fromdual;

dbms_output.put_line(v_result);

end;

4、regexp_replace(x,pattern[,replace_string[,start[,occurrence[, match_option]]]])用於在x中查詢pattern,並將其替換為replae_string。可以參考字串函式 replace(),引數同regexp_instr函式,參考第3

sql **

declare

v_result varchar2(255);

begin

--返回but, soft! what *** through yonder window breaks? 用『***』代替『light』

selectregexp_replace('but, soft! what light through yonder window breaks?','l[[:alpha:]]','***')intov_result

fromdual;

dbms_output.put_line(v_result);

end;

5、regexp_substr(x,pattern[,start[,occurrence[, match_option]]])用於在x中查詢pattern並返回。可以參考字串函式 substr(),引數同regexp_instr函式,參考第3

sql **

declare

v_result varchar2(255);

begin

--返回『light』

selectregexp_substr('but, soft! what light through yonder window breaks?','l[[:alpha:]]')intov_result

fromdual;

dbms_output.put_line(v_result);

end;

**於:

Oracle正規表示式函式

1 正規表示式中的元字元 元字元 意思 例子 說明要匹配的字元是乙個特殊字元 常量或者後者引用。後引用重複上一次的匹配 n 匹配換行符 匹配 匹配 匹配 匹配字串的開頭位置 如果a是字串的第乙個字元,a 匹配 a 匹配字串的末尾位置 如果b是字串的最後乙個字元,b 匹配 b 匹配前面的字元0次或多次...

Oracle正規表示式函式

1 正規表示式中的元字元 元字元 意思 例子 說明要匹配的字元是乙個特殊字元 常量或者後者引用。後引用重複上一次的匹配 n 匹配換行符 匹配 匹配 匹配 匹配字串的開頭位置 如果a是字串的第乙個字元,a 匹配 a 匹配字串的末尾位置 如果b是字串的最後乙個字元,b 匹配 b 匹配前面的字元0次或多次...

Oracle 正規表示式函式

可以匹配字串的開頭 可以匹配字串的結尾 匹配前面的模式元素恰好4次 正規表示式函式 1.regexp like 用於在x中查詢pattern引數中定義的正規表示式。2.regexp instr 用於在x中查詢pattern,返回pattern出現的位置。匹配位置從1開始 3.regexp repla...