Bạn có thể sử dụng $filter
toán tử tổng hợp mảng trên pets
mảng được tạo bởi $lookup
của bạn sân khấu.
Để xuất ra vật nuôi trên 1 năm tuổi, hãy sử dụng
db.users.aggregate([
{
$lookup:
{
from: "pets",
localField: "id",
foreignField: "owner",
as: "pets"
}
},
{
$project:
{
name: 1,
pets:
{
$filter:
{
input: "$pets",
as: "pet",
cond: { $gte: [ "$$pet.age", 1 ] }
}
}
}
}
]);
Để xuất ra những vật nuôi cũ nhất, chỉ cần thay thế cond
trường của $filter
toán tử trong kênh tổng hợp trước đó với
cond: { $eq: [ "$$pet.age", { $max: "$pets.age" } ] }