如何解决使用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 举报,一经查实,本站将立刻删除。