php 数字 intval 超出,php 格式化数字的时候注意数字的范围

php 格式化数字的时候注意数字的范围

发布于 2014-11-25 14:38:52 | 94 次阅读 | 评论: 0 | 来源: 网友投递

PHP开源脚本语言PHP(外文名: Hypertext Preprocessor,中文名:“超文本预处理器”)是一种通用开源脚本语言。语法吸收了C语言、Java和Perl的特点,入门门槛较低,易于学习,使用广泛,主要适用于Web开发领域。PHP的文件后缀名为php。

要文为大家讲解的是在使用php的sprintf和intval函数格式化数字时需要注意数字的大小范围,感兴趣的同学参考下。

因为 数据库中 id 可能会很大 如果使用%d的话,就可能出现因为超出了范围,而到不到正确的结果。所以,个人建议 对id进行格式化的时候 使用%.0f 比 %d 要 好的多。

构造sql语句是 比起来

$sql = 'SELECT *

FROM sdb_comments

WHERE goods_id = '.intval($goods_id).'

AND for_comment_id IS NULL

AND object_type = ".$item."

AND disabled="false"

AND display = "true"';

我更喜欢这样做:

$sql = sprintf('SELECT *

FROM sdb_comments

WHERE goods_id = %.0f

AND for_comment_id IS NULL

AND object_type = "%s"

AND disabled="false"

AND display = "true"', (float)$goods_id, $item);

这个语句还算 简单,如果是更复杂的话,用拼接字符串的话,那简直就是一个噩梦。

使用第二种方式的话,比较方便.但是一个小问题:在格式化数字的时候就需要注意其取值范围。数字操作了取值反问。那么最后返回的sql 也不是我们需要的。

我今天做了个总结:

%d: 2^31~2^31-1(-2147483648~2147483647) (将int转化为有符号十进制)

%b:二进制(将int类型的转化为二进制)

%c:字符(将int类型转化为字符)

%u: 2^32-1(0 ~ 4294967295) (将int转化为有符号十进制)

%f: -2^128-2^128(-3.4E38 ~+3.4E38)(将float转化为float) 本地化

%F: -2^128-2^128(-3.4E38 ~+3.4E38)(将float转化为float) 非本地化

%o (将int转化为八进制)

%s:字符串

%x:将int转化为小写字母的十六进制

%X:将int转化为大写字母的十六进制

因为 数据库中 id 可能会很大 如果使用%d的话,就可能出现因为超出了范围,而到不到正确的结果。所以,个人建议 对id进行格式化的时候 使用%.0f 比 %d 要 好的多。

相关阅读:

php 格式化数字的时候注意数字的范围

php 格式化数字,保留小数点

php number_format() 函数实现千位分组(千位加逗号)来格式化数字的示例

PHP把数字转成人民币大写的函数示例分享

php中数字0和空值的区别分析

PHP实现数字补零功能的2个函数介绍

一个PHP针对数字的加密解密类

PHP中数字检测is_numeric与ctype_digit的区别介绍

一个php下封装的数字分页函数

php生成数字字母的验证码图片

php 把数字转换成汉字的代码

PHP中$_FILES的使用方法及注意事项说明

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值