首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >为了更高的性能,MySQL将IP存储为int?

为了更高的性能,MySQL将IP存储为int?
EN

Stack Overflow用户
提问于 2014-05-13 12:04:38
回答 2查看 342关注 0票数 4

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

例如,我知道192.168.1.1192.16.81.1都存储为19216811,但这并不重要。

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2014-05-13 12:07:29

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

试一试:

代码语言:javascript
复制
$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)的二进制表示。

代码语言:javascript
复制
11000000 10101000 00000000 00000001

为了提高可读性,我分成了8位单元(字节)。这就是电脑所看到的。但这对人类来说是很难记住的。

ascii表示形式将通过将每个字节的值转换为十进制并通过.将它们分开来构建。

代码语言:javascript
复制
11000000 => 192
10101000 => 168
00000000 =>   0
00000001 =>   1

。。什么给了你192.168.0.1,什么东西更容易被人类记住。(除了子网组可读性方面的其他优点)

票数 8
EN

Stack Overflow用户

发布于 2014-05-13 12:09:27

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

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

如果您正在使用PHP,则可以使用ip2long()long2ip(),反之亦然。

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

票数 5
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/23630767

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档