zoukankan      html  css  js  c++  java
  • 使用格式化的时候注意数字的范围

    构造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 要 好的多。

  • 相关阅读:
    CSS中一个冒号和两个冒号有什么区别
    伪类元素实现可伸缩时间轴
    Gulp实现css、js、图片的压缩以及css、js文件的MD5命名
    for 循环进化史
    细谈sass和less中的变量及其作用域
    Vue2.0源码阅读笔记--双向绑定实现原理
    你所不知道的setTimeout
    前端COOKIE与SESSION的区别
    js移动端向左滑动出现删除按钮
    推荐几款屏幕录制工具(可录制GIF)
  • 原文地址:https://www.cnblogs.com/ainiaa/p/1711022.html
Copyright © 2011-2022 走看看