【发布时间】:2017-09-22 21:39:51
【问题描述】:
据我所知,JavaScript 使用 IEEE 754 浮点来处理实数。 使用时出现问题,很常见的问题:
0.1 + 0.2 = 0.30000000000000004
大多数时候,使用“big.js”之类的模块,但问题是在使用 MongoDB 时。
看看这个文件:
{ "_id" : ObjectId("58ff8f721bbfbcd140e472b3"), "value" : 0.1 }
当我像这样运行 $inc 时:
db.dec.update({ _id: ObjectId('58ff8f721bbfbcd140e472b3') }, { $inc: { value: 0.2 }});
结果一点都不好:
{ "_id" : ObjectId("58ff8f721bbfbcd140e472b3"), "value" : 0.30000000000000004 }
我知道为什么会这样,但是有没有办法避免这个问题?
【问题讨论】:
-
为什么这对你来说是个问题?
-
@Thomas 因为我在处理货币
-
对我来说,这听起来像是格式问题,而不是数字系统的问题。检查这个:
var nr = .1 + .2; console.log(nr, nr.toLocaleString("en", {style: "currency", currency: "USD"}))Number#toLocaleString() -
这些浮点错误实际上是一个问题的唯一点是检查相等性时
(.1 + .2) === .3 -
@Thomas 好的,那么如何在 MongoDB 查询中使用它呢?现在我知道你想说什么了,但是如何将它们放在查询中?
标签: javascript mongodb floating-point ieee-754