Sử dụng aggregate
là cách tiếp cận đúng, nhưng bạn cần $unwind
danh sách list
mảng trước khi áp dụng $match
để bạn có thể lọc các phần tử riêng lẻ và sau đó sử dụng $group
để kết hợp nó lại với nhau:
db.test.aggregate([
{ $match: {_id: ObjectId("512e28984815cbfcb21646a7")}},
{ $unwind: '$list'},
{ $match: {'list.a': {$gt: 3}}},
{ $group: {_id: '$_id', list: {$push: '$list.a'}}}
])
kết quả đầu ra:
{
"result": [
{
"_id": ObjectId("512e28984815cbfcb21646a7"),
"list": [
4,
5
]
}
],
"ok": 1
}
Bản cập nhật MongoDB 3.2
Bắt đầu với bản phát hành 3.2, bạn có thể sử dụng $filter
mới toán tử tổng hợp để thực hiện điều này hiệu quả hơn bằng cách chỉ đưa vào danh sách list
các yếu tố bạn muốn trong $project
:
db.test.aggregate([
{ $match: {_id: ObjectId("512e28984815cbfcb21646a7")}},
{ $project: {
list: {$filter: {
input: '$list',
as: 'item',
cond: {$gt: ['$$item.a', 3]}
}}
}}
])