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']);