PLSQL_基礎系列01_正則表達REGEXP_LIKE / SUBSTR / INSTR / REPLACE(案例)


2014-11-30 Created By BaoXinjian

一、摘要


ORACLE中的支持正則表達式的函數主要有下面四個:

1 REGEXP_LIKE :與LIKE的功能相似

2 REGEXP_INSTR :與INSTR的功能相似

3 REGEXP_SUBSTR :與SUBSTR的功能相似

4 REGEXP_REPLACE :與REPLACE的功能相似

它們在用法上與Oracle SQL 函數LIKE、INSTR、SUBSTR 和REPLACE 用法相同。

 

二、調用格式


1. 格式:

REGEXP_INSTR (source_string, pattern [, position [, occurrence [, return_option [, match_parameter ] ] ] ] )

2. 參數說明:

(1). source_string:輸入的字符串

(2). pattern:正則表達式

(3). position:標識從第幾個字符開始正則表達式匹配。(默認為1)

(4). occurrence:標識第幾個匹配組。(默認為1)

(5). return_option:0——返回第一個字符出現的位置。1:pattern下一個字符起始位置。

(6). match_parameter:取值范圍

  •  i:大小寫不敏感;
  •  c:大小寫敏感;
  •  n:點號 . 不匹配換行符號;
  •  m:多行模式;
  •  x:擴展模式,忽略正則表達式中的空白字符。

 

2. REGEXP_LIKE / REGEXP_REPLACE / REGEXP_SUBSTR  / REGEXP_COUNT 格式



三、元字符和字符簇


1. 特殊字符

'^' 匹配輸入字符串的開始位置,在方括號表達式中使用,此時它表示不接受該字符集合。

'$' 匹配輸入字符串的結尾位置。如果設置了 RegExp 對象的 Multiline 屬性,則 $ 也匹配 '\n' 或 '\r'。

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

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

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

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

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

'[]' 標記一個中括號表達式。

'{m,n}' 一個精確地出現次數范圍,m=<出現次數<=n,'{m}'表示出現m次,'{m,}'表示至少出現m次。

'|' 指明兩項之間的一個選擇。例子'^([a-z]+|[0-9]+)$'表示所有小寫字母或數字組合成的字符串。

\num 匹配 num,其中 num 是一個正整數。對所獲取的匹配的引用。

'\' 轉義符。

 

2. 字符簇

[[:alpha:]] 任何字母。

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

[[:alnum:]] 任何字母和數字。

[[:space:]] 任何白字符。

[[:upper:]] 任何大寫字母。

[[:lower:]] 任何小寫字母。

[[unct:]] 任何標點符號。

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

 

3. 各種操作符的運算優先級

\ 轉義符

(), (?, (?=), [] 圓括號和方括號

*, +, ?, {n}, {n,}, {n,m} 限定符

^, $, \anymetacharacter 位置和順序

| “或”操作

 

四、簡單案例


1. 創建測試數據

CREATE TABLE test (mc VARCHAR2 (60)); BEGIN
   INSERT INTO test VALUES   ('112233445566778899'); INSERT INTO test VALUES   ('22113344 5566778899'); INSERT INTO test VALUES   ('33112244 5566778899'); INSERT INTO test VALUES   ('44112233 5566 778899'); INSERT INTO test VALUES   ('5511 2233 4466778899'); INSERT INTO test VALUES   ('661122334455778899'); INSERT INTO test VALUES   ('771122334455668899'); INSERT INTO test VALUES   ('881122334455667799'); INSERT INTO test VALUES   ('991122334455667788'); INSERT INTO test VALUES   ('aabbccddee'); INSERT INTO test VALUES   ('bbaaaccddee'); INSERT INTO test VALUES   ('ccabbddee'); INSERT INTO test VALUES   ('ddaabbccee'); INSERT INTO test VALUES   ('eeaabbccdd'); INSERT INTO test VALUES   ('ab123'); INSERT INTO test VALUES   ('123xy'); INSERT INTO test VALUES   ('007ab'); INSERT INTO test VALUES   ('abcxy'); INSERT INTO test VALUES   ('The final test is is is how to find duplicate words.'); COMMIT; END;

 

2. 案例 REGEXP_LIKE

(1). {}的意思是連續幾個的匹配上面的sql的意思是開頭有1個到3個連續a

(2). 有連續3個a

(3). 以a開頭以e結尾的字符之所以有.是因為如果寫成^a*e$就變成以a開頭中間都是a以e結尾的字符拉 *的意思是匹配它前面的字符

^ab*e$可否查出以a開頭以e結尾的字符呢?

答案是否定的因為*雖然是可以匹配前面的b0次或者多次但是它也僅僅是匹配

以a開頭中間可以有b並且都是b,或者中間沒有字符,以e結尾的字符.

'^[[:alpha:]]+$'的意思是以字母從開頭到結尾都包含字母的字符

(4). 小寫字母或者數字開頭的字符

(5). 小寫字母開頭的字符

(6). "^"就是一個有多種意義的字符元,主要看語意環境如果"^"是字符列中的第一個字符,就表示對這個字符串取反,因此, [^[:digit:]]就是表示查找非數字的模式即字符中不都是數字

(7). 以非數字開頭的字符

 

3. 案例 REGEXP_INSTR

 

 

4. 案例 REGEXP_SUBSTR

 

5. 案例 REGEXP_REPLACE

 

五、復雜案例


1,  REGEXP_SUBSTR 為指定字符串的一部分與正則表達式建立匹配。

示例1:

SQL> select regexp_substr('The zip code 80831 is for falcon, co','[[:digit:]]{5}' ) REGEXP_SUBSTR from dual;
REGEXP_SUBSTR
------------- 80831

示例2:

SQL> select regexp_substr('The zip code 80831 is for falcon, co', '[[:alpha:]]{3,}', 1, 3) REGEXP_SUBSTR from dual; REGEXP_SUBSTR -------------
code

示例3

SQL> select regexp_substr('comments or questions - email feedback@plsqlbook.com', '[[:alnum:]](([_\.\-\+]?[[:alnum:]]+)*)@' 

|| '([[:alnum:]]+)(([\.-]?[[:alnum:]]+)*)\.([[:alpha:]]{2,})') REGEXP_SUBSTR from dual; REGEXP_SUBSTR ---------------------- feedback@plsqlbook.com

 
2.  REGEXP_INSTR 返回與正則表達式匹配的字符和字符串的位置。

SQL> select regexp_instr('The zip code 80831 is for falcon, co', '[[:digit:]]{5}') REGEXP_INSTR from dual; REGEXP_INSTR ------------
14

 
3. REGEXP_REPLACE 與REPLACE函數類似,提供一種修改與所給正則表達式匹配的字符串的方法。作用包括糾正拼寫錯誤、格式化輸入輸出的文本。
如電話號碼的格式為:719-111-1111。使用REGEX_REPLACER的返回值是:

SQL> select regexp_replace('Reformat the phone number 719-111-1111 ...', '[1]?[-.]?(\(?[[:digit:]]{3}\)?)+[- .]?' 

|| '([[:digit:]]{3})[- .]?([[:digit:]]{4})', ' (\1) \2-\3') regexp_replace from dual; REGEXP_REPLACE --------------------------------------------- Reformat the phone number (719) 111-1111 ...


4.  REGEXP_LIKE 運算符與LIKE運算符相似,但是功能更強大,因為它支持使用與此正則表達式與文本進行匹配。

SQL> select ename, job from emp where regexp_like(job, '(clerk|analyst)', 'i'); ENAME JOB ---------- ---------
SMITH CLERK SCOTT ANALYST ADAMS CLERK JAMES CLERK FORD ANALYST MILLER CLERK

 

Thanks and Regards

參考: http://blog.sina.com.cn/s/blog_56cacf83010005aw.html


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM