Vấn đề ở đây là WorkDoneBy
là một mảng được lồng trong một mảng khác (ItemReport
). Do đó, một $filter
là không đủ vì bạn cần phải lặp lại hai lần. Bạn có thể thêm $ map
để lặp qua mảng bên ngoài:
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") ] }
]
}
}
}
}
}
}
}
}
])