php整形类型
来源:互联网 发布:大数据精准推荐竞彩app 编辑:程序博客网 时间:2024/04/29 02:18
问题:服务器数据库中保存ip地址字段用的是有符号整形类型。这样当保存的ip地址ip2long大于2147483647(127.255.255.255)后保存在数据库中的值都是2147483647了。
原因:
大于127.255.255.255的ip地址ip2long后的数值范围超过了字段的存储范围。由于服务器数据库没有打开严格模式,这样超过数据范围的数据就按最大范围值保存了也就是2147483647。
深入:
为了查找原因我在本地机器上ip2long(128.0.0.0)得到的结果是-2147483648。为什么服务器上保存到数据库中的数据却都是正整数。经过上网搜索和PHP手册的查找。发现是int的数值范围引起的。
php手册上有这么一句话:整型数的字长和平台有关,尽管通常最大值是大约二十亿(32 位有符号)。PHP 不支持无符号整数。
本机是windows32为系统,这样保存int的范围是-2^32/2到2^32-1.而服务器上是64位系统这样保存的数值范围就比windows32下的多了。
为了验证猜想:
- php整形类型
- php整形
- 整形类型存储机制
- go语言学习-类型&整形
- PHP:IP转换整形(ip2long)
- PHP:IP转换整形(ip2long)
- php IP转换整形(ip2long)
- php IP转换整形(ip2long)
- php IP转换整形(ip2long)
- PHP基础教程-08 整形变量
- 大数据 整形类型转2进制
- QT类型转换之整形转字符串
- MyBatis 中无效的列类型 整形
- 将整形数据类型转成id类型
- java核心技术之-----整形和浮点类型
- PHP 关于无符号整形Unsigned
- PHP 关于无符号整形Unsigned
- 【VS2010学习笔记】【类型转换】整形转换为CString类型
- SQLServer索引碎片和解决方法
- 浅谈 Linux 内核开发之 PCI 设备驱动
- javascript:void(0)
- 基于OSGI规范Equinox实现的Web组件化松耦合、热插拔架构
- 日志版
- php整形类型
- openGL中的Texture/MultiTexture Mapping
- 端口被谁占有了?
- Postgres 导入到EDB中
- 苹果上免费开源文本编辑器 -MacVim
- Open CV2.0 + VS2008 安装详解
- 无法将bin下某个文件复制到某个bin下
- 屏蔽鼠标右击菜单以及禁止选中页面内容
- final 与 static