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);
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;
结果
首选值=> 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
来源: https://codeday.me/bug/20190527/1164984.html