trong trường hợp này, cần có một trò chơi hay với $ unwind và $ project trong khung tổng hợp
vui lòng xem bên dưới:
db.alumni.aggregate([
{$match: {_id: 'john'}},
{$unwind:"$items"},
{$unwind:"$items.items"},
{$lookup: {
from: 'schools',
localField: 'items.items.school',
foreignField: '_id',
as: 'schoolInfo'}},
{$unwind:"$schoolInfo"},
{$project:{
"_id":1,
"items":[{
"name":"$items.name",
"items":[{
"school":"$schoolInfo._id" ,
"grad":"$items.items.grad" ,
"schoolInfo":"$schoolInfo"
}]
}]
}}
]).pretty()
để xem nó hoạt động như thế nào - hãy thử xóa các giai đoạn tổng hợp khỏi truy vấn và kiểm tra cấu trúc tài liệu.