使用MongoDB从嵌套json返回字段的查询

使用MongoDB从嵌套json返回字段的查询,json,mongodb,aggregation-framework,Json,Mongodb,Aggregation Framework,我的数据库包含以下格式的数据: { "_id" : ObjectId( "abcd" ), "coordinate" : [somevalue, somevalue], "value" : [ { "time" : 1, "characteristics" : "pqrs" }, { "time" : 10, "characteristics" : "pqrs" } ] } 我想找到字段最近的坐标和小于或等于给定值的时间 当前我正在使用此查询: d

我的数据库包含以下格式的数据:

{ "_id" : ObjectId( "abcd" ),
  "coordinate" : [somevalue, somevalue],
   "value" : [ 
   { "time" : 1,
     "characteristics" : "pqrs" },
   { "time" : 10,
     "characteristics" : "pqrs" }  ] }
我想找到字段最近的坐标和小于或等于给定值的时间

当前我正在使用此查询:

db.collection.aggregate({
    coordinate: {
        $geoNear: [latitude, longitude],
        $maxDistance: 10
    },
    "value.time": {
        $lte: 5
    }
})
这一个返回了整个条目,但我想要的是字段:

{ "time" : 1, "characteristics" : "pqrs" }

甚至可以只返回这个字段吗?如果有多个结果,而我只想要一个最接近我的
值。时间
输入的结果,该怎么办?

您可以执行聚合以:

  • 具有指定的
    坐标
    值的项目。时间
  • value
    数组以删除所有内容<5
  • 值数组
  • 按最大值
查询是:

db.collection.aggregate({
    $match: {
        coordinate: {
            $geoNear: [0, 0],
            $maxDistance: 10
        },
        "value.time": {
            $lte: 5
        }
    }
}, {
    $project: {
        value: {
            $filter: {
                input: "$value",
                as: "value",
                cond: { $lte: ["$$value.time", 5] }
            }
        }
    }
}, {
    $unwind: "$value"
}, {
    $group: {
        _id: "$_id",
        time: { $max: "$value.time" },
        characteristics: { $first: "$value.characteristics" }
    }
})
样本输出:

{ "_id" : ObjectId("588a8c3080a14de2d654eb7b"), "time" : 4, "characteristics" : "pqrs" }
{ "_id" : ObjectId("588a89327fe89686fd2210b2"), "time" : 1, "characteristics" : "pqrs" }

显示E QUERY[thread1]语法错误:缺少:在属性id@(shell):1:199之后出现错误您使用的是哪个mongodb版本?