MySQL将IP存储为int以获得更高的性能?

时间:2014-05-13 12:04:38

标签: php mysql database

我有一个每秒钟有很多查询的数据库。查询搜索IP地址值。 那么将IP(例如34.549.53.23)存储为int值:345495323是否合理? 查询会更快吗?

我知道例如123.12.3.123和123.1.2.3.1.2.3都存储为123123123但这没关系。

2 个答案:

答案 0 :(得分:8)

虽然我认为这是微优化,但您可以使用函数ip2long()将IP地址的ascii表示转换为32位整数,并long2ip()将其转换回来。

试一试:

$int = ip2long('192.168.0.1');
echo $int; // 3232235521

$ip = long2ip(3232235521);
echo $ip; // 192.168.0.1

顺便说一句,IP的字符串表示与它的整数表示之间的转换效果与您期望的不同。你看到192.168.0.1将而不是转换为19216801.看看它,很明显这不可能被重新转换。是19.216.80.1还是192.168.0.1?

IP地址是32位整数,以二进制格式存储(与任意数字一样)。让我们看一下3232235521 (192.168.0.1)的二进制表示:

11000000 10101000 00000000 00000001

我已经分成8位单位(字节)以提高可读性。这就是计算机所看到的。但这对人类来说很难记住。

将通过将每个字节的值转换为十进制并将它们分隔为.来构建其中的ascii表示:

11000000 => 192
10101000 => 168
00000000 =>   0
00000001 =>   1

..是什么让你192.168.0.1,人类更容易记住什么。 (除了关于子网组可读性的其他一些优点)

答案 1 :(得分:5)

是的,查询会更快。另外,要将IP保存为整数,请使用mysql的INET_ATON()并从整数使用INET_NTOA()获取IP地址。请参阅此页面以获取更多信息

http://dev.mysql.com/doc/refman/5.0/en/miscellaneous-functions.html

如果您尝试使用PHP,可以使用ip2long()long2ip()反之

参考http://www.php.net/manual/en/function.ip2long.php