Mysql
 sql >> Database >  >> RDS >> Mysql

Differenza tra tipo di dati float e decimale

Questo è quello che ho trovato quando ho avuto questo dubbio.

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

Il decimale ha fatto esattamente quello che dovrebbe fare in questi casi, ha troncato il resto, perdendo così la parte 1/3.

Quindi per le somme è meglio il decimale, ma per le divisioni è meglio il float, fino a un certo punto, ovviamente. Voglio dire, l'uso di DECIMAL non ti darà in alcun modo una "aritmetica a prova di errore".

Spero questo sia di aiuto.