Mysql
 sql >> Base de données >  >> RDS >> Mysql

Quel type de données MySQL utiliser pour une adresse IP ?

Étant donné que les adresses IPv4 ont une longueur de 4 octets, vous pouvez utiliser un INT (UNSIGNED ) qui a exactement 4 octets :

`ipv4` INT UNSIGNED

Et INET_ATON et INET_NTOA pour les convertir :

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

Pour les adresses IPv6, vous pouvez utiliser un BINARY à la place :

`ipv6` BINARY(16)

Et utilisez le inet_pton de PHP et inet_ntop pour la conversion :

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