Тъй като IPv4 адресите са дълги 4 байта, можете да използвате INT
(НЕПОДПИСАНО
)
който има точно 4 байта:
`ipv4` INT UNSIGNED
И INET_ATON
и INET_NTOA
за да ги конвертирате:
INSERT INTO `table` (`ipv4`) VALUES (INET_ATON("127.0.0.1"));
SELECT INET_NTOA(`ipv4`) FROM `table`;
За IPv6 адреси можете да използвате BINARYкод>
вместо това:
`ipv6` BINARY(16)
И използвайте PHP на inet_pton
и inet_ntop
за преобразуване:
'INSERT INTO `table` (`ipv6`) VALUES ("'.mysqli_real_escape_string(inet_pton('2001:4860:a005::68')).'")'
'SELECT `ipv6` FROM `table`'
$ipv6 = inet_pton($row['ipv6']);