backreference OracleRegex中的反向引用

來源:互聯網
上載者:User

 

這是Oracle對Regex的backreference的描述

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

 

反向引用的引入使得Regex的匹配功能變得更加強大,介紹兩個在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

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.