本文主要是介绍为什么ROUND(9.95,1) 返回 9.9 而不是 10.0? 难道9.95 不该向上进位么,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
SQLite 内部使用二进制运算,9.95用 64-bit IEEE 浮点数 ( SQLite 内部使用的) 表示为 9.949999999999999289457264239899814128875732421875。所以当你输入 "9.95"时, SQLite 就理解为上述的数字,进而四舍五入得到9.9。这个问题在处理浮点二进制数总会产生。通常的规则是十进制的有限浮点数通常无法表示为二进制有限浮点数,只能由最接近的二进制数来代替。这个近似数会非常接近原数,但总一些细微的不同,所以可能无法得到你预期的结果。这篇关于为什么ROUND(9.95,1) 返回 9.9 而不是 10.0? 难道9.95 不该向上进位么的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!