使用
aggregate是正确的方法,但在应用数组之前需要先
$unwind对
list数组进行
$match过滤,以便可以过滤单个元素,然后用于
$group将其放回原处:
db.test.aggregate([ { $match: {_id: ObjectId("512e28984815cbfcb21646a7")}}, { $unwind: '$list'}, { $match: {'list.a': {$gt: 3}}}, { $group: {_id: '$_id', list: {$push: '$list.a'}}}])
输出:
{ "result": [ { "_id": ObjectId("512e28984815cbfcb21646a7"), "list": [ 4, 5 ] } ], "ok": 1}
MongoDB 3.2更新
从3.2发行版开始,您可以使用新的
$filter聚合运算符来提高效率,只需list在$project:中包括所需的元素即可:
db.test.aggregate([ { $match: {_id: ObjectId("512e28984815cbfcb21646a7")}}, { $project: { list: {$filter: { input: '$list', as: 'item', cond: {$gt: ['$$item.a', 3]} }} }}])
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)