找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 1086|回复: 0
打印 上一主题 下一主题

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

[复制链接]

2560

主题

2560

帖子

7622

积分

论坛元老

Rank: 8Rank: 8

积分
7622
跳转到指定楼层
楼主
发表于 2018-2-14 08:59:55 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

            构造sql语句是 比起来
[U]复制代码[/U] 代码如下:
$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"';

我更喜欢这样做:
[U]复制代码[/U] 代码如下:
$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 Smarty date_format [格式化时间日期]
  • PHP 防注入函数(格式化数据)
  • 利用php递归实现无限分类 格式化数组的详解
  • php自定义的格式化时间示例代码
  • PHP文件大小格式化函数合集
  • php实现的返回数据格式化类实例
  • php时间戳格式化显示友好的时间函数分享
  • php格式化时间戳显示友好的时间实现思路及代码
  • php格式化日期实例分析
  • PHP中常用的字符串格式化函数总结
  • PHP实现格式化文件数据大小显示的方法
            
  • 分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
    收藏收藏
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    用户反馈
    客户端