热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

在mysql中如何用int类型代替varchar类型存储IP与PHP的转换

2019独角兽企业重金招聘Python工程师标准1、首先我们应该先明白为什么要这样存储ip而用varchar直接存储IP呢?其实做任何程序设计都要在功能实现的基

2019独角兽企业重金招聘Python工程师标准>>> hot3.png

1、首先我们应该先明白为什么要这样存储ip而用varchar直接存储IP呢?
其实做任何程序设计都要在功能实现的基础上最大限度的优化性能。而数据库设计是程序设计中不可忽略的一个重要部分,所以巧存IP地址可以一定程度获得很大提升。

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

接下来我们找一个ip地址分析一下它应int存储的过程:
先来看IP的结构, 127.0.0.1
学计算机的对2的n次方比较敏感,一看就猜到是由 4个8位的二进制数字组成, 对, 你猜的没错,就是这样!也就是说IP转换成二进制可以这样:  

select concat(bin(127),lpad(bin(0),8,0),lpad(bin(0),8,0),lpad(bin(1),8,0));

把每一位的前边补0, 然后拼接起来,得到这样的结果: 1111111000000000000000000000001    

 系统的INET_ATON()函数也是这么算的,不信可以对比一下结果:

select bin(inet_aton('127.0.0.1'));

得到的结果也是这样:  1111111000000000000000000000001      
所以得出结论: INET_ATON() 就是把IP的每一段转为二进制拼接起来,然后将这个32位的二进制数字转为10进制
示例:

select INET_ATON('127.0.0.1'); -----------------转为数字
select INET_NTOA(2130706433); ------------------转为IP

 为什么这么存储呢?      
有人说节省空间, 也对, 不过比较蛋疼, 现在的硬盘那么便宜在乎这点空间?更为合理的解释是, 方便查询, 比如要查某一网段的所有IP就可以 :
 

select * from table where ip between inet_aton('192.168.0.1') and inet_aton('192.168.0.255');

到这里我们就已经把如何用int类型代替varchar类型存储ip的过程分析完了。上面的分析中我们用到了两个函数INET_ATON()和INET_NTOA(),下面我们用具体的实例来说一下这两个函数的具体用法。
IP的表字段可以设置为INT(10)就好,如果IP获取不到可以直接存0代表获取不到IP的意思。

2、实例分析

将IP以整型的方式存储到数据库中
在实现某些功能时有时会用到用户的IP地址,因为IP地址有四段,在保存到MySQL数据库中的时候可能会使用varchar(15)或者char(15),其实还有更好的方式那就是将IP地址转换成整型,这样占用空间更小,查询速度快,同时还方便比较。在数据库设计时要用无符号INT UNSIGNED,否则长度不够。下面给出主要PHP代码:

$ip = '这里是获取到的IP';
echo $intip = sprintf('%u',ip2long($ip)); //转换为无符号整型
echo long2ip($intip);//将整型转换为ip
?>


这样保存到数据库之后也很容易比较,例如类似between之类的语句,在sql语句中也可以通过函数实现转换:
将IP地址转换为整型可以使用

select inet_aton(ip) from users;

将整型转换为IP地址可以使用

select inet_ntoa(intip) from users;


 


转:https://my.oschina.net/u/2364788/blog/2873642



推荐阅读
  • Web安全入门:MySQL基础操作与SQL注入防范
    本文详细介绍了MySQL数据库的基础操作命令,包括数据库和表的基本管理,以及数据的增删查改等常用操作。同时,针对Web安全领域常见的SQL注入问题,提供了初步的理解和防范措施。 ... [详细]
  • 本文详细探讨了在Windows Server 2003环境下遇到MySQL连接失败(错误代码10061)的解决方案,包括通过卸载特定的Windows更新和调整系统注册表设置的方法。 ... [详细]
  • mysql 分库分表策略_【数据库】分库分表策略
    关系型数据库本身比较容易成为系统瓶颈,单机存储容量、连接数、处理能力都有限。当单表的数据量达到1000W或100G以后,由于查询维度较多, ... [详细]
  • 使用Python轻松合并大量复杂Excel文件
    当面对大量的Excel文件时,如何高效地将它们合并成一个文件成为了一项挑战。本文将指导初学者如何利用Python的几个库,在几十行代码内完成这一任务。 ... [详细]
  • 开发笔记:新手DVWACSRF
    开发笔记:新手DVWACSRF ... [详细]
  • 导读上一篇讲了zsh的常用字符串操作,这篇开始讲更为琐碎的转义字符和格式化输出相关内容。包括转义字符、引号、print、printf的使用等等。其中很多内容没有必要记忆,作为手册参 ... [详细]
  • ###########性能监控脚本###########################!binbash#监控cpu系统负载IPifconfigeth0|grepinetaddr ... [详细]
  • 本文介绍了在 Android 开发中如何实现像素 (px)、缩放独立像素 (sp) 和密度独立像素 (dp) 之间的相互转换。这些方法对于确保应用在不同屏幕尺寸和分辨率上的适配至关重要。 ... [详细]
  • 本文通过一个实际案例,详细介绍了如何使用Excel VBA和FSO(FileSystemObject)对象来提取指定文件夹中的所有文件名称,并将其以超链接的形式添加到Excel表格中。 ... [详细]
  • 本文旨在介绍Three.js的基础概念及其应用场景。Three.js是一个基于WebGL的JavaScript库,用于在网页上创建和显示3D图形。文中将从Canvas的基本功能出发,探讨其局限性,并引出WebGL及Three.js的解决方案。 ... [详细]
  • 本文介绍了如何在 Linux 系统上构建网络路由器,特别关注于使用 Zebra 软件实现动态路由功能。通过具体的案例,展示了如何配置 RIP 和 OSPF 协议,以及如何利用多路由器查看工具(MRLG)监控网络状态。 ... [详细]
  • 本文详细探讨了在不同服务器上运行的PHP程序如何成功连接MySQL数据库的方法,包括常见的连接失败原因及解决方案。 ... [详细]
  • 本文由Jogis撰写,详细探讨了React中的组件设计模式,包括控制组件、非控制组件及混合模型组件,分析了各自的优缺点及其应用场景。 ... [详细]
  • 本文详细介绍了C++标准模板库(STL)中各容器的功能特性,并深入探讨了不同容器操作函数的异常安全性。 ... [详细]
  • 本文探讨了如何利用ES6提供的新功能来更改JavaScript对象中的属性名,特别是当需要将API返回的数据格式化为特定组件所需的格式时。 ... [详细]
author-avatar
陌-天佑_807
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有