1. 程式人生 > >backreference Oracle正規表示式中的反向引用

backreference 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