1

Mysql怎样存储IP地址


概述

在Mysql中并没有提供针对IP地址存储的数据格式,在开发中我们可以选择使用char、varchar、int来存储,根据mysql字段类型选择的规则:字段类型定义使用最合适(最小)、最简单的数据类型,优先选择使用int类型来存储,其在逻辑运算上也要比char、varchar更快

int类型存储IP地址

在Mysql中提供了两个函数,用来把IP地址与数字类型的相互转化

  • inet_aton():把IP地址转化为数字

这种算法其实借用了国际上对各国IP地址的区分中使用的ip number。
a.b.c.d 的ip number是:
a 256的3次方 + b 256的2次方 + c 256的1次方 + d 256的0次方。

mysql> select inet_aton('255.255.255.255');
+------------------------------+
| inet_aton('255.255.255.255') |
+------------------------------+
|                   4294967295 |
+------------------------------+
1 row in set (0.00 sec)
  • inet_ntoa():把数字转化成IP地址

    mysql> select inet_ntoa(4294967295);
    +-----------------------+
    | inet_ntoa(4294967295) |
    +-----------------------+
    | 255.255.255.255       |
    +-----------------------+
    1 row in set (0.00 sec)

在路上
534 声望26 粉丝