Mysql
 sql >> Database >  >> RDS >> Mysql

Quale tipo di dati MySQL utilizzare per un indirizzo IP?

Poiché gli indirizzi IPv4 sono lunghi 4 byte, è possibile utilizzare un INT (UNSIGNED ) che ha esattamente 4 byte:

`ipv4` INT UNSIGNED

E INET_ATON e INET_NTOA per convertirli:

INSERT INTO `table` (`ipv4`) VALUES (INET_ATON("127.0.0.1"));
SELECT INET_NTOA(`ipv4`) FROM `table`;

Per gli indirizzi IPv6 è possibile utilizzare un BINARY invece:

`ipv6` BINARY(16)

E usa inet_pton di PHP e inet_ntop per la conversione:

'INSERT INTO `table` (`ipv6`) VALUES ("'.mysqli_real_escape_string(inet_pton('2001:4860:a005::68')).'")'
'SELECT `ipv6` FROM `table`'
$ipv6 = inet_pton($row['ipv6']);