float データ型と decimal データ型の違い 質問する

float データ型と decimal データ型の違い 質問する

MySQL で float データ型と decimal データ型を使用するとどのような違いが生じますか?

どちらをいつ使用すればよいですか?

ベストアンサー1

これこの疑問を抱いたときに私が見つけたものです。

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 を使用しても、決して「失敗のない計算」は得られません。

おすすめ記事