使用格式化的时候注意数字的范围
来源:互联网 发布:藏剑二少捏脸数据 编辑:程序博客网 时间:2024/05/05 19:24
构造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 要 好的多。
- 使用格式化的时候注意数字的范围
- 要注意int的数字范围
- JS 比较两个数字大小时候的注意!
- myfaces使用时候注意的小问题。
- 套接字使用时候的一些注意
- 使用UIPickerView需要注意的问题时候
- LoaderMax使用的时候onProgress注意
- 在使用颜色选择器的时候注意
- 使用@Transactional时候的注意点
- fftw使用时候需注意的内容
- java 数字格式化 NumberFormat类的使用
- 数字格式化类NumberFormat 的使用
- 使用DecimalFormat进行数字的格式化
- 关于DecimalFormat数字格式化的基本使用
- JS在用户输入的时候格式化数字为财务数字,如"123,123,1.123,1"
- 数字的格式化
- 数字的格式化
- 数字的格式化
- CString及string,char *与其他数据类型的转换和操作 .
- java 如何自定义异常 用代码展示 真心靠谱
- 让注册体验来得更简单点吧
- php 构造方法
- smarty2.x foreach 和section的使用
- 使用格式化的时候注意数字的范围
- 禁止firefox 缓存input
- smarty 的 modifier插件
- 【转】【用以自勉】哈佛大学凌晨4点半的景象
- ubuntu10.04 gedit 支持 中文 以及 打开 空文件提示段错误的解决办法【转】
- 【转载】一个老程序员和学生对作为PHP程序员的你们说的话
- 【转】Unix信号量中基础知识介绍
- 【转】HTTP 状态代码
- 一位软件工程师的6年总结【转】