Oracle
 sql >> Base de Dados >  >> RDS >> Oracle

Oracle:Convertendo um endereço IPv4 em um número?

  • extraia os quatro octetos do endereço usando regexp_substr.
  • reconstitua o valor deslocando os octetos de volta para suas posições originais.

O regexp pode ser relativamente caro, portanto, se você estiver fazendo muito isso, considere armazenar em cache o valor numérico em sua tabela junto com o endereço 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 

Para completar, veja como ir para o outro lado.
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