Aby pomóc innym w tym, @SiddhartAjmera ma właściwą odpowiedź. Musiałem tylko dodać podwójne cudzysłowy dla zagnieżdżonych wartości, takich jak „campaign.clientid”.
Ostateczny kod powinien wyglądać następująco:
db.somecollection.aggregate([
{
"$lookup": {
"from": "campaigns",
"localField": "campId",
"foreignField": "_id",
"as": "campaign"
}
},
{
"$unwind": "$campaign"
},
{
"$lookup": {
"from": "entities",
"localField": "campaign.clientid",
"foreignField": "_id",
"as": "campaign.client"
}
},
{
"$project": {
"_id": 1,
"campId": 1,
"articleId": 1,
"campaign._id": 1,
"campaign.clientid": 1,
"campaign.client._id": 1,
"campaign.client.username": 1
}
}
]);