我个人觉得,ip地址保存到数据库中,112.98.105.155没有1885497755好,前者必须声明15位varchar,后者只需要声明11位的int类型,
所以比较喜欢用后者,
下面介绍php和mysql中,这两种类型的转换
php:首先通过代码获取到客户端ip,例如得到:112.98.105.155
然后通过函数sprintf ( "%u", ip2long ( $ip ) );得到int类型的ip: 1885497755。
这里说明一下,为什么ip2long就已经转换了,还要用sprintf,因为仅仅用ip2long 有可能产生负数。
反之,则用long2ip($ip)得到112.98.105.155这种格式的ip
mysql中:
- INET_ATON(expr)
给出一个作为字符串的网络地址的点地址表示,返回一个代表该地址数值的整数。地址可以是4或8比特地址。
mysql> SELECT INET_ATON('112.98.105.155');
-> 1885497755
产生的数字总是按照网络字节顺序。如上面的例子,数字按照 209×2563 + 207×2562 + 224×256 + 40 进行计算。
INET_ATON() 也能理解短格式 IP 地址:
mysql> SELECT INET_ATON('127.0.0.1'), INET_ATON('127.1');
-> 2130706433, 2130706433
注释: 在存储由INET_ATON() 产生的值时,推荐你使用 INT UNSIGNED 列。假如你使用 (带符号) INT列, 则相应的第一个八位组大于127的IP 地址值会被截至 2147483647 (即, INET_ATON('127.255.255.255') 所返回的值)。请参见11.2节,“数值类型”。
- INET_NTOA(expr)
给定一个数字网络地址 (4 或 8 比特),返回作为字符串的该地址的电地址表示。
mysql> SELECT INET_NTOA(1885497755);
-> '112.98.105.155'