Bạn cần có ít nhất MongoDB v3.4.4
Chiếu "array.a": 1
sẽ trả về ["A", "A", "A"]
.Kể từ array
của bạn trường là một mảng, chúng ta cần sử dụng $map
toán tử cho phép lặp.
Để lặp lại các khóa đối tượng, chúng tôi cần chuyển đổi nó thành mảng với $ objectToArray nhà điều hành.
"c": { "c": [
"x": true, {k: "x", v: true},
"y": true, -> {k: "y", v: true},
"z": false {k: "z", v: false},
} ]
Sau đó, chúng tôi áp dụng $filter
toán tử để chỉ lấy k:v
các cặp có v
là true
.
db.collection.aggregate([
{
$match: {}
},
{
$project: {
array: {
$map: {
input: "$array",
as: "arr",
in: {
a: "$$arr.a",
b: "$$arr.b",
c: {
$size: {
$filter: {
input: {
$objectToArray: {
$ifNull: [
"$$arr.c",
{}
]
}
},
cond: {
$eq: [
"$$this.v",
true
]
}
}
}
}
}
}
}
}
}
])