使用 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 使用上舍入。所有的数值都必须精确到确定的精度,但会产生微小的浮点值差异。因为浮点数字的二进制表示法可以采用很多合法舍入规则中的任意一条,因此我们不可能可靠地量化浮点值。

解决方案 »

  1.   

    在之前用float类型对应java的float类型一直都是很顺利的存进去了 可是在今天的时候出现了这样一种情况就是录入的时候是123.07然后存到数据库的时候变成了123.6999212123231我想问一下 这是读取的物理内存中的脏数据呢还是上面所说的 IEEE 754 规范提供了四种舍入模式:舍入到最接近的值、上舍入、下舍入和舍入到零 中舍入到最近的值呢
      

  2.   

    程序中是读取的Excel的数据由Float.valueOf("123.07")这样转换得到的在数据库中有存了正常的数据但是总有那么几列会出现这种情况
      

  3.   


    读取Excel的内容Debug模式的截图数据传入到与数据库映射的实体类后的截图存到数据库后的截图