程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> Oracle數據庫 >> Oracle教程 >> backreferenceOracle正則表達式中的反向引用

backreferenceOracle正則表達式中的反向引用

編輯:Oracle教程

\

這是Oracle對正則表達式的backreference的描述

從定義中可以看到,當匹配表達式中已()的形式將一個子串包含起來,後面就可以以\?的形式來引用。\1對應第一個(),\2對應第二個...

反向引用的引入使得正則表達式的匹配功能變得更加強大,介紹兩個在oracle正則函數中的應用

regexp_like

regexp_like('1211233','^([0-9])(\d)\1\1\2(\d)\3$')

上面這個例子中,匹配表達式裡,\1表示第一個([0-9]),這個表達式要判斷字符串中的第3、4位數字是否和第1位相同,而不僅僅是匹配[0-9]

regexp_replace

regexp_replace('1234567','^(.)(.)(.)(.)(.)(.)','\1\2\5')

這裡,將符合匹配表達式中的部分替換掉,換成滿足\1\2\5的內容,即第一個(.)第二個(.)和第五個(.)

猜猜這裡會返回什麼?

由於^(.)(.)(.)(.)(.)(.)匹配了字符串的前6位,因此結果為\1\2\5||第6位之後的部分,即1257

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved