mysql 货币 字段_mysql货币使用什么字段类型?

MySQL中处理货币数据通常使用Decimal或Numric类型,因它们能确保精确的精度,适合存储如金钱等需要精准数值的信息。不同于可能产生误差的float和double类型,Decimal和Numric将值作为字符串存储,保证了小数点后的位数无误。举例来说,DECIMAL(9,2)可以存储-9999999.99到9999999.99的值。在实际应用中,为了避免浮点数存储的误差,推荐使用Decimal或Numric类型。" 106126861,9422556,"Java集合框架详解:ArrayList, LinkedList, Vector与泛型
摘要由CSDN通过智能技术生成

在mysql中,货币常使用Decimal和Numric类型的字段表示,这两种类型被MySQL实现为同样的类型;它们被用于保存值,该值的准确精度是极其重要的值,例如与金钱有关的数据。

9e2cd1e457e98f9d1cf5e862f4f2b5f6.png

开发中,货币在数据库中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类型。

插入数据:

8255687634bbdcf840674f815614eeb7.png

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

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

4ae6cd5f3aff7eb8e81b421615fba274.png

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

推荐教程:mysql视频教程

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值