微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

使用geoWithin的MongoDB查询工作错误

如何解决使用geoWithin的MongoDB查询工作错误

我有一个mongoDB有关的问题。让我们代表我们有一个集合points,其中有一点:

db.points.insert(
  {
    name: 'point1',location: {
      type: "Point",coordinates: [-11,-1]
    }
  }
);

我用geoWithin编写了以下查询

let foundPoints = db.points.find(
    {
        location: {
            $geoWithin: {
                $geometry: {
                    type: 'polygon',coordinates: [[[-15,-5],[-5,5],[-15,-5]]]
                }
            }
        }
    }
);

const answer = foundPoints.map(doc => doc.name);

让我们看到点[-11,-1]在给定三角形的侧面,但是查询没有找到该点。我想知道我做错了什么。你能帮忙吗?

谢谢。

解决方法

如果点(-11,-1)是平面中的坐标,则它们仅在(-15,-5)-(-5,5)的直线上。

如果球体上是经度和纬度,则点(-11,-1)在该三角形之外。

https://geojson.io处绘制点和三角形,该点实际上位于三角形西北约100米处。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。