Mysql
 sql >> Base de Dados >  >> RDS >> Mysql

Qual tipo de dados MySQL usar para um endereço IP?


Como os endereços IPv4 têm 4 bytes, você pode usar um INT (UNSIGNED ) que tem exatamente 4 bytes:
`ipv4` INT UNSIGNED

E INET_ATON e INET_NTOA para convertê-los:
INSERT INTO `table` (`ipv4`) VALUES (INET_ATON("127.0.0.1"));
SELECT INET_NTOA(`ipv4`) FROM `table`;

Para endereços IPv6, você pode usar um BINARY em vez de:
`ipv6` BINARY(16)

E use PHPs inet_pton e inet_ntop para conversão:
'INSERT INTO `table` (`ipv6`) VALUES ("'.mysqli_real_escape_string(inet_pton('2001:4860:a005::68')).'")'
'SELECT `ipv6` FROM `table`'
$ipv6 = inet_pton($row['ipv6']);