SQL反模式学习笔记10 取整错误

目标:使用小数取代整数

反模式:使用Float类型

根据IEEE754标识,float类型使用二进制格式编码实数数据。

缺点:(1)舍入的必要性: 并不是所有的十进制中描述的信息都能使用二进制存储,处于一些必要的因素,

浮点数通常是舍入到了一个非常接近的值。

                     举例:select rate from A where id=123   --Result:59.95

                             select * from A where rate=59.95 --Result:empty set;no rows match.

                             select * from A where ABS(rate-59.95)<0.000001   --这个才能正确查出数据!

(2)将浮点数视作“近似相等”

如何识别反模式:任何使用Float、Real或者Double Percent类型的设计都有可能是反模式

合理使用反模式:如果要存储的值取值范围很大,大于integer、numeric的范围,那只能用float了。科学计算类的程序通常使用float。

解决方案:使用numeric、decimal类型

使用numeric、decimal代替float,他们不会对存储的有理数进行舍入,因此select * from A where rate=59.95会返回记录。

          注意:numeric、decimal在sqlserver乃至sybase中,是完全一样的。

结论:尽可能不要使用浮点数

SQL反模式,系列学习汇总

1SQL反模式学习笔记1 开篇

2、SQL反模式学习笔记2 乱穿马路

3、SQL反模式学习笔记3 单纯的树

4、SQL反模式学习笔记4 建立主键规范【需要ID】

5、SQL反模式学习笔记5 外键约束【不用钥匙的入口】

6、SQL反模式学习笔记6 支持可变属性【实体-属性-值】

7、SQL反模式学习笔记7 多态关联

8、SQL反模式学习笔记8 多列属性

9、SQL反模式学习笔记9 元数据分裂

10、SQL反模式学习笔记10 取整错误

11、SQL反模式学习笔记11 限定列的有效值

12、SQL反模式学习笔记12 存储图片或其他多媒体大文件

13、SQL反模式学习笔记13 使用索引

14、SQL反模式学习笔记14 关于Null值的使用

15、SQL反模式学习笔记15 分组

16、SQL反模式学习笔记16 使用随机数排序

17、SQL反模式学习笔记17 全文搜索

18、SQL反模式学习笔记18 减少SQL查询数据,避免使用一条SQL语句解决复杂问题

19、SQL反模式学习笔记19 使用*号,隐式的列

20、SQL反模式学习笔记20 明文密码

21、SQL反模式学习笔记21 SQL注入

22、SQL反模式学习笔记22 伪键洁癖,整理数据

上一篇:SpringMVC:学习笔记(10)——整合Ckeditor且实现图片上传


下一篇:APUE学习笔记——10.9 信号发送函数kill、 raise、alarm、pause