在 MySQL 中使用 float 和 decimal 数据类型有什么区别?
我什么时候应该使用哪个?
这是我有这个疑问时发现的。
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 不会以任何方式为您提供“防故障算术”。
希望这可以帮助。