项目中涉及到金钱的计算时,数据库字段的使用

涉及到金额的计算,数据库中在字段应设置为decimal类型,较为精确,
实体类映射类型为:java.math.BigDecimal
xml中jdbcType:DECIMAL

一般用decimal,长度18,保存2位小数,具体看业务

 

在java的开发中,货币在数据库中MySQL常用Decimal和Numric类型表示,这两种类型被MySQL实现为同样的类型。他们被用于保存值,该值的准确精度是极其重要的值,例如与金钱有关的数据。当声明一个类是这些类型之一时,精度和规模的能被(并且通常是)指定;例如:

salary DECIMAL(9,2)

在这个例子中,9(precision)代表将被用于存储值的总的小数位数,而2(scale)代表将被用于存储小数点后的位数。因此,在这种情况下,能被存储在salary列中的值的范围是从-9999999.99到9999999.99。

           DECIMAL和NUMERIC值作为字符串存储,而不是作为二进制浮点数,以便保存那些值的小数精度。一个字符用于值的每一位、小数点(如果scale>0)和“-”符号(对于负值)。如果scale是0,DECIMAL和NUMERIC值不包含小数点或小数部分。

           不使用float或者double的原因:因为float和double是以二进制存储的,所以有一定的误差。

比如:在数据库中c1,c2,c3分别存储类型是float(10.2),decimal(10.2),float类型。

         插入数据:

        

INTO test (c1,c2,c3) VALUES (1234567.23,1234567.23,1234567.23)

数据在数据库中的存储结果是:

         可以看出,使用float类型存储有一定的误差。因此使用decimal或者numric类型。
 

你可能感兴趣的:(项目中涉及到金钱的计算时,数据库字段的使用)