IT貓撲網(wǎng):您身邊最放心的安全下載站! 最新更新|軟件分類|軟件專題|手機(jī)版|論壇轉(zhuǎn)貼|軟件發(fā)布

您當(dāng)前所在位置: 首頁數(shù)據(jù)庫Oracle → Oracle10g的SQL正則表達(dá)式

Oracle10g的SQL正則表達(dá)式

時間:2015-06-28 00:00:00 來源:IT貓撲網(wǎng) 作者:網(wǎng)管聯(lián)盟 我要評論(0)

  Oracle 8 和Oracle 9i中缺乏靈活性的SQL 正則表達(dá)式最終在Oracle 10g中得到了解決。Oracle 數(shù)據(jù)庫目前內(nèi)建了符合POSIX 標(biāo)準(zhǔn)的正則表達(dá)式。

  四個新的函數(shù)分別是:REGEXP_LIKE、REGEXP_INSTR、REGEXP_SUBSTR、和 REGEXP_REPLACE。它們在用法上與Oracle SQL 函數(shù)LIKE、INSTR、SUBSTR 和REPLACE 用法,但是它們使用POSIX 正則表達(dá)式代替了老的百分號(%)和通配符(_)字符。

  POSIX 正則表達(dá)式由標(biāo)準(zhǔn)的元字符(metacharacters)所構(gòu)成:

  '^' 表示字符串的開始

  '$' 表示字符串的結(jié)束

  '.' 表示任何字符

  字符的范圍,比如說'[a-z]',表示任何ASCII 小寫字母,與字符類"[[:lower:]]"" 等價

  '?' 允許一個后繼字符匹配零次或一次

  '+' 允許一個后繼字符匹配一次或多次

  '*' 表示零次或多次

  可以使用"{m,n}" 指定一個精確地出現(xiàn)范圍,其意思是"出現(xiàn)從m 次到n 次";"{m}" 表示"正好m次";而"{m,}" 表示"至少m次"。還可以使用圓括號組合字符的集合,使用"|"(豎線)表示可替換。例如,字符串'^([a-z]+|[0-9]+)$'將匹配所有由小寫字母或數(shù)字組合成的字符串。

  REGEXP_LIKE 與LIKE 操作符相似。如果第一個參數(shù)匹配正則表達(dá)式它就解析為TRUE。例如WHERE REGEXP_LIKE(ENAME,'^J[AO]','i') 將在ENAME 以JA 或JO 開始的情況下返回一行數(shù)據(jù)。'I' 參數(shù)指定正則表達(dá)式是大小寫敏感的。另外還可以在CHECK 約束和函數(shù)索引中指定REGEXP_LIKE。例如:

  ALTER TABLE EMP ADD CONSTRAINT REGEX01

  CHECK (REGEXP_LIKE(ENAME,'^[[:alpha:]]+$'));

  這條語句使得ENAME 字段只能包含字母和數(shù)字字符(也就是說沒有空格或者標(biāo)點(diǎn)符號)。試圖插入或者更新這些數(shù)據(jù)將導(dǎo)致一個ORA-2290 異常,或者檢查約束的有效性。

  REGEXP_INSTR 與INSTR 函數(shù)類似。它返回一個字符串中匹配一個正則表達(dá)式的第一個子串的開始位置。例如:

  SELECT REGEXP_INSTR('The total is $400 for your purchase.','$[[:digit:]]+')

  FROM DUAL;

  這個查詢返回14,即$400在字符串的開始位置。另外還可以指定子串出現(xiàn)的次數(shù);開始搜索的位置;是返回匹配的位置還是返回匹配之后字符的位置。

  REGEXP_SUBSTR 返回匹配一個正則表達(dá)式的子串。雖然結(jié)合使用SUBSTR 和REGEXP_INSTR 及LENGTH 也可以實(shí)現(xiàn)這一功能,但是使用這個函數(shù)卻更為簡單。

  SELECT REGEXP_INSTR('one,two,three','[^,]*') FROM DUAL;

  這個查詢返回'one',將第一個參數(shù)看成一個逗號分隔的列表并返回第一個逗號之前的所有字符。

  REGEXP_REPLACE 返回初始參數(shù)被匹配子串替換之后的結(jié)果。例如:

  SELECT REGEXP_REPLACE('The temperature is 23°F',

  '([[:digit:]])+°F',

  ('1'-32)*5/9||'°C')

  FROM DUAL;

  這個查詢將查找一個華氏溫度并將其轉(zhuǎn)換為攝氏度。它將返回:'The temperature is -5°C'。

關(guān)鍵詞標(biāo)簽:Oracle10g

相關(guān)閱讀

文章評論
發(fā)表評論

熱門文章 Oracle中使用alter table來增加,刪除,修改列的語法 Oracle中使用alter table來增加,刪除,修改列的語法 oracle中使用SQL語句修改字段類型-oracle修改SQL語句案例 oracle中使用SQL語句修改字段類型-oracle修改SQL語句案例 誤刪Oracle數(shù)據(jù)庫實(shí)例的控制文件 誤刪Oracle數(shù)據(jù)庫實(shí)例的控制文件 為UNIX服務(wù)器設(shè)置Oracle全文檢索 為UNIX服務(wù)器設(shè)置Oracle全文檢索

相關(guān)下載

    人氣排行 oracle中使用SQL語句修改字段類型-oracle修改SQL語句案例 Oracle中使用alter table來增加,刪除,修改列的語法 ORACLE SQL 判斷字符串是否為數(shù)字的語句 ORACLE和SQL語法區(qū)別歸納(1) oracle grant 授權(quán)語句 ORACLE修改IP地址后如何能夠使用 如何加速Oracle大批量數(shù)據(jù)處理 Oracle刪除表的幾種方法