Masalahnya di sini adalah WorkDoneBy
adalah larik yang bersarang di larik lain (ItemReport
). Oleh karena itu tunggal $filter
tidak cukup karena Anda perlu mengulangi dua kali. Anda dapat menambahkan $map
untuk mengulangi array luar:
db.records.aggregate([
{
"$project": {
"ItemReport": {
$map: {
input: "$ItemReport",
as: "ir",
in: {
WorkDoneBy: {
$filter: {
input: "$$ir.WorkDoneBy",
as: "value",
cond: {
"$and": [
{ "$ne": [ "$$value.DateCompleted", null ] },
{ "$gt": [ "$$value.DateCompleted", new Date("2017-01-01T12:00:00.000Z") ] },
{ "$lt": [ "$$value.DateCompleted", new Date("2018-12-31T12:00:00.000Z") ] }
]
}
}
}
}
}
}
}
}
])