查询MongoDB问题

问题描述

我正在尝试(失败)查询具有以下结构的集合:

{
     origin : { lat : #,lng : #},destination : { lat : #,lng #}
}

使用此查询


{
     origin : { lat : { $gte: in.lat-1,$lte : in.lat+1},lng : { $gte: in.lng-1,$lte : in.lng+1}
                },destination : { lat : { $gte: out.lat-1,$lte : out.lat+ 1},lng : { $gte: out.lng-1,$lte : out.lng +1}}
}

基本上,我正在尝试查找其坐标在我的进/出经纬度/经度的某个范围内(此处为1)的文档。但是,当我通过此查询时,它与我应该知道的文档不匹配。有提示吗?

解决方法

我不知道它为什么起作用,但是我将起点和终点分成了两个子部分(lat和lng),并查询了对我有用的那些子项。

,

要请求子文档,您必须执行origin.lat { $gte ...}

db.collection.find({
  "origin.lat": {
    "$gte": 7,"$lte": 10
  },"origin.lng": {
    "$gte": 7,"destination.lat": {
    "$gte": 7,"destination.lng": {
    "$gte": 7,"$lte": 10
  }
})

尝试here