文档章节

MySQL怎样存储IP地址

Surjur
 Surjur
发布于 2015/06/02 13:56
字数 560
阅读 433
收藏 42
点赞 1
评论 2

为什么要问如何存储IP

首先就来阐明一下部分人得反问:为什么要问IP得怎样存,直接varchar类型不就得了吗?

其实做任何程序设计都要在功能实现的基础上最大限度的优化性能。而数据库设计是程序设计中不可忽略的一个重要部分,所以巧存IP地址可以一定程度获得很大提升。

 

利用函数算法处理

在MySQL中没有直接提供IP类型字段,但如果有两个函数可以把IP与最大长度为10位数字类型互转,所以使用int类型存储IP比varchar类型存储IP地址性能要提升很多,减少不少空间。因为varchar是可变长形,需要多余的一个字节存储长度。另外int型在逻辑运算上要比varchar速度快。

 

IP转数字函数inet_aton()

我们转换下几个常用的IP地址

01 mysql> select inet_aton('255.255.255.255');
02 +------------------------------+
03 | inet_aton('255.255.255.255') |
04 +------------------------------+
05 |                   4294967295 |
06 +------------------------------+
07 1 row in set (0.00 sec)
08  
09 mysql> select inet_aton('192.168.1.1');   
10 +--------------------------+
11 | inet_aton('192.168.1.1') |
12 +--------------------------+
13 |               3232235777 |
14 +--------------------------+
15 1 row in set (0.00 sec)
16  
17 mysql> select inet_aton('10.10.10.10');
18 +--------------------------+
19 | inet_aton('10.10.10.10') |
20 +--------------------------+
21 |                168430090 |
22 +--------------------------+
23 1 row in set (0.00 sec)

所以IP的表字段可以设置为INT(10)就好,如果IP获取不到可以直接存0代表获取不到IP的意思

 

数字转IP函数inet_ntoa()

01 mysql> select inet_ntoa(4294967295);
02 +-----------------------+
03 | inet_ntoa(4294967295) |
04 +-----------------------+
05 | 255.255.255.255       |
06 +-----------------------+
07 1 row in set (0.00 sec)
08  
09 mysql> select inet_ntoa(3232235777);
10 +-----------------------+
11 | inet_ntoa(3232235777) |
12 +-----------------------+
13 | 192.168.1.1           |
14 +-----------------------+
15 1 row in set (0.00 sec)
16  
17 mysql> select inet_ntoa(168430090);
18 +----------------------+
19 | inet_ntoa(168430090) |
20 +----------------------+
21 | 10.10.10.10          |
22 +----------------------+
23 1 row in set (0.00 sec)
24  
25 mysql> select inet_ntoa(0);       
26 +--------------+
27 | inet_ntoa(0) |
28 +--------------+
29 | 0.0.0.0      |
30 +--------------+
31 1 row in set (0.00 sec)

注意,0转换为 0.0.0.0

 

整型字段的比较比字符串效率高很多,这也符合一项优化原则:字段类型定义使用最合适(最小),最简单的数据类型。
inet_aton()算法,其实借用了国际上对各国IP地址的区分中使用的ip number。
a.b.c.d 的ip number是:
a * 256的3次方 + b * 256的2次方 + c * 256的1次方 + d * 256的0次方。

© 著作权归作者所有

共有 人打赏支持
Surjur
粉丝 26
博文 193
码字总数 12053
作品 0
杭州
程序员
加载中

评论(2)

clouddyy
clouddyy
好文,收藏!
xcorp
xcorp
这个不错

暂无相关文章

Boost库编译应用

版本:Boost 1.66.0 Windows库编译 官网指南:直接执行bootstrap.bat处理文件即可,可以我却遇到一堆的问题。 环境:Windows 10 + Visual Studio 2017 Boost编译出来库命名 boost库生成文件命...

水海云 ⋅ 12分钟前 ⋅ 0

解决Eclipse发布到Tomcat丢失依赖jar包的问题

如果jar文件是以外部依赖的形式导入的。Eclipse将web项目发布到Tomcat时,是不会自动发布这些依赖的。 可以通过Eclipse在项目上右击 - Propertics - Deployment Assembly,添加“Java Build ...

ArlenXu ⋅ 12分钟前 ⋅ 0

iview tree组件层级过多时可左右滚动

使用vue+iview的tree组件,iview官网iview的tree树形控件 问题描述:tree层级过多时左右不可滚动 问题解决:修改overflow属性值 .el-tree-node>.el-tree-node_children { overflow: vi...

YXMBetter ⋅ 14分钟前 ⋅ 0

分布式锁

1.通过数据库实现 http://www.weizijun.cn/2016/03/17/%E8%81%8A%E4%B8%80%E8%81%8A%E5%88%86%E5%B8%83%E5%BC%8F%E9%94%81%E7%9A%84%E8%AE%BE%E8%AE%A1/ 2.ZK实现:curator-recipes分布式锁的......

素雷 ⋅ 22分钟前 ⋅ 0

Sublime Text3 快捷键

选择类 Ctrl+D 选中光标所占的文本,继续操作则会选中下一个相同的文本。 Alt+F3 选中文本按下快捷键,即可一次性选择全部的相同文本进行同时编辑。举个栗子:快速选中并更改所有相同的变量名...

AndyZhouX ⋅ 29分钟前 ⋅ 0

XamarinAndroid组件教程RecylerView自定义适配器动画

XamarinAndroid组件教程RecylerView自定义适配器动画 如果RecyclerViewAnimators.Adapters命名空间中没有所需要的适配器动画,开发者可以自定义动画。此时,需要让自定义的动画继承Animation...

大学霸 ⋅ 29分钟前 ⋅ 0

eureka 基础(二)

使用Eureka服务器进行身份验证 如果其中一个eureka.client.serviceUrl.defaultZone网址中包含一个凭据(如http://user:password@localhost:8761/eureka)),HTTP基本身份验证将自动添加到您...

明理萝 ⋅ 32分钟前 ⋅ 1

Kubernetes(五) - Service

Kubernetes解决的另外一个痛点就是服务发现,服务发现机制和容器开放访问都是通过Service来实现的,把Deployment和Service关联起来只需要Label标签相同就可以关联起来形成负载均衡,基于kuberne...

喵了_个咪 ⋅ 32分钟前 ⋅ 0

更新队友POM文件后报错

打开报错的地方的pom及其引用方法所在文件的pom,观察其版本号是否一致,不一致进行更改

森火 ⋅ 45分钟前 ⋅ 0

IDEA使用sonarLint

一、IDEA如何安装SonarLint插件 1.打开 Idea 2.点击【File】 3.点击【Settings】 4.点击【Plugins】 5.在搜索栏中输入“sonarlint”关键字 6.点击【Install】进行安装 7.重启Idea 二、IDEA如...

开源中国成都区源花 ⋅ 51分钟前 ⋅ 0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部