Problem polega na tym, że WorkDoneBy
jest tablicą zagnieżdżoną w innej tablicy (ItemReport
). Dlatego pojedynczy $filter
nie wystarczy, ponieważ musisz powtórzyć iterację dwukrotnie. Możesz dodać $map
do iteracji po zewnętrznej tablicy:
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") ] }
]
}
}
}
}
}
}
}
}
])