使用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版本?