mysql里记录货币用什么字段类型好?
2018-03-06 16:42
441 查看
在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类型。
插入数据:
数据在数据库中的存储结果是:
可以看出,使用float类型存储有一定的误差。因此使用decimal或者numric类型。
在这个例子中,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类型。
相关文章推荐
- MySQL中日期类型数据的使用:如何让字段保存记录的创建时间和最后修改时间
- MYSQL查询通过date类型的字段查询一段时间记录
- mysql字段类型 唯一索引 记录不重复设置
- MySQL 数据库中的字段类型 varchar 和 char 的主要区别是什么?哪 种字段的查找效率要高,为什么?
- 地理位置经纬度在Mysql中用什么字段类型
- mysql 货币字段类型的存储
- 记录:java执行mysql语句查询字段类型:timestamp返回页面显示会多出个 .0,自己如何处理的
- mysql字段类型 唯一索引 记录不重复设置
- Mysql 更新字段类型异常处理:ERROR 1265 (01000): Data truncated for column 'xxx' at row 1
- mysql如何去除两个字段数据相同的记录?
- mysql字段类型对应javabean属性
- mysql 字段存储类型
- mysql字段类型说明与用途
- Mysql 字段数据类型/长度及表类型详细说明
- MYSQL的索引类型:PRIMARY, INDEX,UNIQUE,FULLTEXT有什么区别?各适用
- MySQL数据类型和常用字段属性总结
- 主键设计用什么字段类型比较好?
- MySQL字段类型介绍
- mysql查询字段不为空的记录
- MySQL数据类型和常用字段属性总结