我似乎無法找出此正則表達式在PL/SQL
中不起作用的原因。IPv6正則表達式(RegEx)不能在PL/SQL中工作
if (REGEXP_LIKE(v,'/^(?>(?>([a-f0-9]{1,4})(?>:(?1)){7}|(?!(?:.*[a-f0-9](?>:|$)){8,})((?1)(?>:(?1)){0,6})?::(?2)?)|(?>(?>(?1)(?>:(?1)){5}:|(?!(?:.*[a-f0-9]:){6,})(?3)?::(?>((?1)(?>:(?1)){0,4}):)?)?(25[0-5]|2[0-4][0-9]|1[0-9]{2}|[1-9]?[0-9])(?>\.(?4)){3}))$/iD')) then
這是用於驗證IPv4和IPv6,它來自這裏:https://stackoverflow.com/a/1934546/3112803
不知道這有什麼關係,但我也問了一下就完了D
標誌這個問題:What Does This Regular Expression (RegEx) Flag Mean /iD
出於某種原因,這個正則表達式適用於我的測試最在這個網站:http://regex101.com/但PL/SQL
一切都是無效的。
我的意思是由最的是,有一些情況下,我覺得很失敗,但我一直在尋找了幾天,這是最好的一個我能找到的是在512個字符(512使用REGEXP_LIKE
時的限制PL/SQL
)
我很感激任何幫助。謝謝!
這些是我使用的測試案例...
{1: Initial address, regex should say valid/match}
select isValid('2001:0db8:0000:0000:0000:ff00:0042:8329','ipv6') from dual;
{2: After removing all leading zeroes, regex should say valid/match}
select isValid('2001:db8:0:0:0:ff00:42:8329','ipv6') from dual;
{3: After omitting consecutive sections of zeroes, regex should say valid/match}
select isValid('2001:db8::ff00:42:8329','ipv6') from dual;
{4: The loopback address, regex should say valid/match}
select isValid('0000:0000:0000:0000:0000:0000:0000:0001','ipv6') from dual;
{5: The loopback address be abbreviated to ::1 by using both rules, regex should say valid/match}
select isValid('::1','ipv6') from dual;
{6: This should be valid/match}
select isValid('ABCD:ABCD:ABCD:ABCD:ABCD:ABCD:192.168.158.190','ipv6') from dual;
{7: This should be valid/match}
select isValid('::','ipv6') from dual;
{8: IPv6 applications to communicate directly with IPv4 applications, regex should say valid/match}
select isValid('0:0:0:0:0:ffff:192.1.56.10','ipv6') from dual;
{9: should NOT be valid/match}
select isValid('::ffff:192.1.56.10/96','ipv6') from dual;
{old formats used for tunneling, these should NOT be valid/matches}
{10}
select isValid('0:0:0:0:0:0:192.1.56.10','ipv6') from dual;
{11}
select isValid('::192.1.56.10/96','ipv6') from dual;
{These 4 should be valid/match}
{12}
select isValid('::FFFF:129.144.52.38','ipv6') from dual;
{13}
select isValid('::129.144.52.38','ipv6') from dual;
{14}
select isValid('::FFFF:d','ipv6') from dual;
{15}
select isValid('1080:0:0:0:8:800:200C:417A','ipv6') from dual;
{These 4 should NOT be valid/match}
{16}
select isValid('::FFFF:d.d.d','ipv6') from dual;
{17}
select isValid('::FFFF:d.d','ipv6') from dual;
{18}
select isValid('::d.d.d','ipv6') from dual;
{19}
select isValid('::d.d','ipv6') from dual;
有人告訴我,試驗#6錯了,ABCD:ABCD:ABCD:ABCD:ABCD:ABCD:192.168.158.190
是不是一個有效的IPv6地址,是正確的?
測試用例8-11來自這裏:http://publib.boulder.ibm.com/infocenter/iseries/v5r3/index.jsp?topic=%2Frzai2%2Frzai2ipv6addrformat.htm但我被告知10 & 11已不再使用。
從XML正則表達式改性不幸的是,Oracle支持僅正則表達式語言的狹窄部分。您的正則表達式在Oracle中不起作用。 –
第二次,測試用例6無效。 10和11也不是。 –
是的,我知道。它也在下面提到。我會更新這個問題,以免混淆。這個被接受的答案是迄今爲止我發現的最好答案。然而@nhahtdh不同意你關於項目#6的格式。 – gfrobenius