为了账号安全,请及时绑定邮箱和手机立即绑定

如何比较 mongodb 中的浮点值?

如何比较 mongodb 中的浮点值?

Go
aluckdog 2021-08-23 17:53:45
我有一个集合名称 myplace,其中包含 place_name(string)、latitude(float64) 和 longitude(float64)。现在我有一个纬度 12.34567,我需要搜索 mongodb 是否存在这个纬度。我试过这样,但它返回空 db.myplace.find({"latitude":12.3456})
查看完整描述

2 回答

?
沧海一幻觉

TA贡献1824条经验 获得超5个赞

比较浮点值的相等性通常是一个坏主意,因为在各种浮点运算中发生的舍入会导致您期望相等的某些值具有略微不同的值。


更好的解决方案是检查两个浮点值之间的差异是否小于特定的误差范围E。对于这种查询,检查变成了范围检查,例如:


12.3456 - E < latitude < 12.3456 + E

如本问题所述,这种查询可以用 mgo 表示为:


lat := 12.3456

E := 0.0001

q := c.Find(bson.M{"latitude": bson.M{"$gt": lat - E, "$lt": lat + E}})


查看完整回答
反对 回复 2021-08-23
  • 2 回答
  • 0 关注
  • 281 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信