转载:php中的unsigned long类型  

jackxiang 2013-3-27 21:29 | |

最近遇到一个问题:
在mysql的表中有一个bigint(20) unsigned 的字段 F_flag.这个bigint相当于一个unsigned long.这个字段的每个二进制位是否为1代表一定意义.简单的说把这个字段当一个64位的bitmap来用.现在需要更新表中一条记录的这个字段.使64,22,1位变位1.view sourceprint?



但是你会发现执行完这条语句后,数据库中的记录并没有更新成你所想要的值.
为什么?
首先我们来看看php中的变量到底是怎么样的:view sourceprint?


php中的变量都是一个这样的union数据结构.相当于所有的整形都是用long表示的.而当这个数超出long的范围.它会自动的转换成double去表示.因此前面的$flag已经是一个double了.这样就会存在精度问题.最后导致数据库的更新不正确.
改进后的做法.view sourceprint?


这样就不会出现问题.因为php中的<<不会引起转换,而只是简单的二进制操作.sprintf也只是简单的对c语言中vsprintf的一个简单包装.返回的字符串符合我们的要求.
来自:http://bbs.phpchina.com/thread-185419-1-1.html

作者:jackxiang@向东博客 专注WEB应用 构架之美 --- 构架之美,在于尽态极妍 | 应用之美,在于药到病除
地址:http://jackxiang.com/post/6174/
版权所有。转载时必须以链接形式注明作者和原始出处及本声明!

评论列表
发表评论

昵称

网址

电邮

打开HTML 打开UBB 打开表情 隐藏 记住我 [登入] [注册]