日期:2014-05-18  浏览次数:20463 次

求解释MSSQL联机帮助的一段话
使用 float 和 real 数据
float 和 real 数据类型被称为近似数据类型。float 和 real 的使用遵循有关近似数值数据类型的 IEEE 754 规范。

近似数值数据类型并不存储为许多数字指定的精确值,它们只储存这些值的最近似值。在很多应用程序中,指定值与存储的近似值之间的微小差异并不明显。但有时这些差异也较明显。由于 float 和 real 数据类型的这种近似特性,因此当要求使用精确数值时,比如在财务应用程序、需要舍入的操作或等值核对中,请勿使用这些数据类型。而应使用 integer、decimal、money 或 smallmoney 数据类型。

在 WHERE 子句搜索条件(特别是 = 和 <> 运算符)中,应避免使用 float 列或 real 列。float 列和 real 列最好只限于 > 比较或 < 比较。

IEEE 754 规范提供了四种舍入模式:舍入到最接近的值、上舍入、下舍入和舍入到零。Microsoft SQL Server 2005 使用上舍入。所有的数值都必须精确到确定的精度,但会产生微小的浮点值差异。因为浮点数字的二进制表示法可以采用很多合法舍入规则中的任意一条,因此我们不可能可靠地量化浮点值。


------解决方案--------------------
【浮点数字的二进制表示法可以采用很多合法舍入规则中的任意一条,因此我们不可能可靠地量化浮点值】

非数据库,也是这样的
------解决方案--------------------
123.07然后存到数据库的时候变成了123.6999212123231

可能吗?

123.70吧?
------解决方案--------------------
数据库只适合存储数据,强烈建议不要在数据库中进行计算,否则精度控制很不方便。
------解决方案--------------------
探讨
比如在财务应用程序、需要舍入的操作或等值核对中,请勿使用这些数据类型。而应使用 integer、decimal、money 或 smallmoney 数据类型。