时间:2021-07-01 10:21:17 帮助过:13人阅读
浮点数为表示很大的数,丢失了部分精度
所以在比较时应用: 两个数的差的绝对值小于某个极小数时就视为相等 的策略
或者用 round 取得有效数后在比较
如果你的应用需要有精确的小数位数(比如金融)那么应该使用 DECIMAL 类型
这个还是蛮正常的 毕竟float数据没有办法保证数据的精度呢
浮点数为表示很大的数,丢失了部分精度
所以在比较时应用: 两个数的差的绝对值小于某个极小数时就视为相等 的策略
或者用 round 取得有效数后在比较
如果你的应用需要有精确的小数位数(比如金融)那么应该使用 DECIMAL 类型
建议修改类型为DECIMAL
select ..., abs(Payment-feiyong) as aform ......where feiyong>0 and Payment>0having a > 1e-5
select ..., (Payment-feiyong) as aform ......where feiyong>0 and Payment>0having a > 1e-5