sql >> Databáze >  >> RDS >> Mysql

Rozdíl mezi datovým typem float a decimální

Toto je to, co jsem našel, když jsem měl tuto pochybnost.

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

Desetinná čárka udělala přesně to, co v těchto případech dělat má, zbytek zkrátila, čímž ztratila 1/3 části.

Takže pro součty je lepší desetinné číslo, ale pro dělení je lepší plovoucí, až do určitého bodu, samozřejmě. Chci říct, že použití DECIMAL vám v žádném případě neposkytne „aritmetiku důkazu selhání“.

Snad to pomůže.



  1. Kurz hodnocení hvězdičkami Jquery pomocí php a mysql

  2. Vysoká dostupnost PostgreSQL s architekturami Master-Slave a Master-Master

  3. SQL pro generování seznamu čísel od 1 do 100

  4. Přečtěte si o oprávněních na úrovni tabulky MySQL