- ekstrak empat oktet alamat menggunakan regexp_substr.
- bentuk kembali nilai dengan menggeser oktet kembali ke posisi semula.
Regexp mungkin relatif mahal, jadi jika Anda sering melakukan ini, Anda mungkin mempertimbangkan untuk menyimpan nilai numerik dalam tabel di samping alamat IP.
with addr as (select '239.255.2.51' ip from dual)
select ip, to_number(regexp_substr(ip, '\d+', 1, 1)) * 16777216 +
to_number(regexp_substr(ip, '\d+', 1, 2)) * 65536 +
to_number(regexp_substr(ip, '\d+', 1, 3)) * 256 +
to_number(regexp_substr(ip, '\d+', 1, 4)) n
from addr;
IP N
------------- ----------
239.255.2.51 4026466867
Untuk kelengkapannya, berikut cara sebaliknya.
with addr as (select 4026466867 n from dual)
select n, mod(trunc(n/16777216),256) ||'.'||
mod(trunc(n/65536), 256) ||'.'||
mod(trunc(n/256), 256) ||'.'||
mod(n, 256) ip
from addr;
N IP
---------- ------------
4026466867 239.255.2.51