1
を掛けるとき 、結果はDOUBLE
に変換されています 。これはより正確であり、その結果、10進近似の誤差を見ることができます。 FLOAT
を割り当てると、同じことがわかります。 列からDOUBLE
列。
CREATE TABLE `my_table` (
`my_float_col` float,
`my_double_col` double
);
INSERT INTO my_table (my_float_col) values (1.2355);
UPDATE my_table SET my_double_col = my_float_col;
SELECT my_float_col, my_double_col, my_float_col * 1 FROM my_table;
+--------------+--------------------+--------------------+
| my_float_col | my_double_col | my_float_col * 1 |
+--------------+--------------------+--------------------+
| 1.2355 | 1.2354999780654907 | 1.2354999780654907 |
+--------------+--------------------+--------------------+
なぜDOUBLE
が返されるのかよくわかりません ドキュメント
言う:
しかし、それは明らかに何が起こっているのかです。