一尘不染

浮点数和十进制数据类型的区别

java

在 MySQL 中使用浮点数和十进制数据类型有什么区别?。

我什么时候应该使用哪个?


阅读 292

收藏
2021-05-31

共2个答案

一尘不染

这是我在有这个疑问时发现的。

mysql> create table numbers (a decimal(10,2), b float);
mysql> insert into numbers values (100, 100);
mysql> select @a := (a/3), @b := (b/3), @a * 3, @b * 3 from numbers \G
*************************** 1. row ***************************
  @a := (a/3): 33.333333333
  @b := (b/3): 33.333333333333
@a + @a + @a: 99.999999999000000000000000000000
@b + @b + @b: 100

小数点在这种情况下完成了应该做的事情,它截断了其余部分,从而失去了 1/3 部分。

所以对于总和,小数更好,但对于除法,浮点数更好,当然,在某种程度上。我的意思是,使用 DECIMAL 不会以任何方式为您提供“失败证明算法”。

希望这可以帮助。

2021-05-31
一尘不染

十进制用于固定数量,例如您需要特定小数位数的货币。浮点数用于存储......浮点精度数字。

2021-05-31