這條語句使得ENAME 字段只能包含字母和數(shù)字字符(也就是說沒有空格或者標(biāo)點(diǎn)符號(hào))。試圖插入或者更新這些數(shù)據(jù)將導(dǎo)致一個(gè)ORA-2290 異常,或者檢查約束的有效性。REGEXP_INSTR 與INSTR 函數(shù)類似。它返回一個(gè)字符串中匹配一個(gè)正則表達(dá)式的第一個(gè)子串的開始位置。例如: SELECT REGEXP_INSTR('The total is $400 for your purchase.','$[[:digit:]]+')
FROM DUAL; 這個(gè)查詢返回14,即$400在字符串的開始位置。另外還可以指定子串出現(xiàn)的次數(shù);開始搜索的位置;是返回匹配的位置還是返回匹配之后字符的位置。 REGEXP_SUBSTR 返回匹配一個(gè)正則表達(dá)式的子串。雖然結(jié)合使用SUBSTR 和REGEXP_INSTR 及LENGTH 也可以實(shí)現(xiàn)這一功能,但是使用這個(gè)函數(shù)卻更為簡單。 SELECT REGEXP_INSTR('one,two,three','[^,]*') FROM DUAL; 這個(gè)查詢返回'one',將第一個(gè)參數(shù)看成一個(gè)逗號(hào)分隔的列表并返回第一個(gè)逗號(hào)之前的所有字符。 REGEXP_REPLACE 返回初始參數(shù)被匹配子串替換之后的結(jié)果。例如:
SELECT REGEXP_REPLACE('The temperature is 23°F',
'([[:digit:]])+°F',
('/1'-32)*5/9'°C')
FROM DUAL;
這個(gè)查詢將查找一個(gè)華氏溫度并將其轉(zhuǎn)換為攝氏度。它將返回:'The temperature is -5°C'。