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)