我有一个集合名称 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}})
- 2 回答
- 0 关注
- 281 浏览
添加回答
举报
0/150
提交
取消