Oracle 和Oracle i中缺乏靈活性的SQL 正則表達式最終在Oracle g中得到了解決Oracle 數據庫目前內建了符合POSIX 標准的正則表達式
四個新的函數分別是REGEXP_LIKEREGEXP_INSTRREGEXP_SUBSTR和 REGEXP_REPLACE它們在用法上與Oracle SQL 函數LIKEINSTRSUBSTR 和REPLACE 用法但是它們使用POSIX 正則表達式代替了老的百分號(%)和通配符(_)字符
POSIX 正則表達式由標准的元字符(metacharacters)所構成
^ 表示字符串的開始
$ 表示字符串的結束
表示任何字符
字符的范圍比如說[az]表示任何ASCII 小寫字母與字符類[[:lower:]] 等價
? 允許一個後繼字符匹配零次或一次
+ 允許一個後繼字符匹配一次或多次
* 表示零次或多次
可以使用{mn} 指定一個精確地出現范圍其意思是出現從m 次到n 次{m} 表示正好m次而{m} 表示至少m次還可以使用圓括號組合字符的集合使用|(豎線)表示可替換例如字符串^([az]+|[]+)$將匹配所有由小寫字母或數字組合成的字符串
REGEXP_LIKE 與LIKE 操作符相似如果第一個參數匹配正則表達式它就解析為TRUE例如WHERE REGEXP_LIKE(ENAME^J[AO]i) 將在ENAME 以JA 或JO 開始的情況下返回一行數據I 參數指定正則表達式是大小寫敏感的另外還可以在CHECK 約束和函數索引中指定REGEXP_LIKE例如
ALTER TABLE EMP ADD CONSTRAINT REGEX
CHECK (REGEXP_LIKE(ENAME^[[:alpha:]]+$));
這條語句使得ENAME 字段只能包含字母和數字字符(也就是說沒有空格或者標點符號)試圖插入或者更新這些數據將導致一個ORA 異常或者檢查約束的有效性
REGEXP_INSTR 與INSTR 函數類似它返回一個字符串中匹配一個正則表達式的第一個子串的開始位置例如
SELECT REGEXP_INSTR(The total is $ for your purchase$[[:digit:]]+)
FROM DUAL;
這個查詢返回即$在字符串的開始位置另外還可以指定子串出現的次數開始搜索的位置是返回匹配的位置還是返回匹配之後字符的位置
REGEXP_SUBSTR 返回匹配一個正則表達式的子串雖然結合使用SUBSTR 和REGEXP_INSTR 及LENGTH 也可以實現這一功能但是使用這個函數卻更為簡單
SELECT REGEXP_INSTR(onetwothree[^]*) FROM DUAL;
這個查詢返回one將第一個參數看成一個逗號分隔的列表並返回第一個逗號之前的所有字符
REGEXP_REPLACE 返回初始參數被匹配子串替換之後的結果例如
SELECT REGEXP_REPLACE(The temperature is °F
([[:digit:]])+°F
()*/||°C)
FROM DUAL;
這個查詢將查找一個華氏溫度並將其轉換為攝氏度它將返回The temperature is °C
From:http://tw.wingwit.com/Article/program/Oracle/201311/18878.html