【问题标题】:MongoDB floating point value precision?MongoDB浮点值精度?
【发布时间】: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


【解决方案1】:

如果您确切知道所需的小数位数,您可以使用Number((.1+.2).toFixed(1))。或者,您可以为 mongodb 使用 orm,例如 mongoose,并为您的数据库文档定义模型,并使用模型中的一些代码定义您想要的精度。

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2010-09-27
    • 2011-05-17
    • 1970-01-01
    • 2023-03-31
    • 2018-07-06
    • 2017-11-30
    • 2019-11-10
    相关资源
    最近更新 更多