Vì bạn đang sử dụng $unwind
bạn có thể làm điều đó dễ dàng bằng cách thêm $match
kể từ biểu thức:"inquiries.routeHistory.status": "ended"
sẽ trả về true
nếu có bất kỳ tài liệu trong routeHistory
có trạng thái như vậy:
db.collection.aggregate([
{
$unwind: "$inquiries"
},
{
$match: {
"inquiries.routeHistory.status": "ended"
}
},
{
$addFields: {
"inquiries.routeHistory": {
$filter: {
input: "$inquiries.routeHistory",
cond: {
$eq: [ { $max: "$inquiries.routeHistory.routeDate" }, "$$this.routeDate" ]
}
}
}
}
},
{
$group: {
_id: "$_id",
callId: { $first: "$callId" },
caller: { $first: "$caller" },
inquiries: { $push: "$inquiries" }
}
}
])