Vì địa chỉ IPv4 dài 4 byte, bạn có thể sử dụng INT
( CHƯA ĐĂNG KÝ
)
có chính xác 4 byte:
`ipv4` INT UNSIGNED
Và INET_ATON
và INET_NTOA
để chuyển đổi chúng:
INSERT INTO `table` (`ipv4`) VALUES (INET_ATON("127.0.0.1"));
SELECT INET_NTOA(`ipv4`) FROM `table`;
Đối với địa chỉ IPv6, bạn có thể sử dụng BINARY
thay vào đó:
`ipv6` BINARY(16)
Và sử dụng inet_pton
của PHP
và inet_ntop
để chuyển đổi:
'INSERT INTO `table` (`ipv6`) VALUES ("'.mysqli_real_escape_string(inet_pton('2001:4860:a005::68')).'")'
'SELECT `ipv6` FROM `table`'
$ipv6 = inet_pton($row['ipv6']);