Bạn có thể sử dụng $ map
để áp dụng điều kiện của bạn cho mỗi shipment
và sau đó sử dụng $ allElementsTrue
bên trong $ expr
để kiểm tra xem tất cả các yếu tố đó có khớp không:
db.shop_orders.aggregate([
{
$match: { shipments: { $exists: true, $ne: [] } }
},
{
$match: {
$expr: {
$allElementsTrue: {
$map: {
input: "$shipments",
as: "shipment",
in: {
$and: [
{ $eq: [ "$$shipment.status", "Delivered" ] },
{ $lte: [ "$$shipment.deliveredAt", new Date("2018-07-28") ] }
]
}
}
}
}
}
}
])