MySQL FLOOR函数意外结果

CREATE TABLE table_name (col_a double(10,2), col_b double(10,2), col_c double(10,2));
INSERT INTO table_name VALUES(36.3, 0, 6.3);

enter image description here

QUERY

SELECT FLOOR(36.3- 0 -6.3), FLOOR(col_a - col_b - col_c) AS calc, col_a, col_b, col_c 
FROM table_name LIMIT 1;

结果

enter image description here

首选值=> FLOOR(36.3-0-6.3)导致30.

第二个选定值=> FLOOR(col_a – col_b – col_c)等于FLOOR(36.3-0-6.3)导致29但我期待30

为什么这些选择获得两个不同的值?

最佳答案
当使用double或float类型时,这是MySQL中的一个已知问题,它不像我们看到的那样内部存储.

如果你阅读了MySQL documentation,你会发现一个建议的解决方法,即使用decimal而不是double.您可以在下面的Fiddle中看到,当使用decimal(10,2)作为列类型时,所有这些都按预期工作:

SQLFiddle

转载注明原文:MySQL FLOOR函数意外结果 - 代码日志