Това е това, което открих, когато имах това съмнение.
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 част.
Така че за сумите десетичната запетая е по-добра, но за деленията float е по-добра, до определен момент, разбира се. Искам да кажа, че използването на DECIMAL няма да ви даде „аритметика за доказване на неуспех“ по никакъв начин.
Надявам се това да помогне.