Мне нужно выполнить следующий запрос в MongoDB в моем коде C #. Я использую MongoDB.Driver 2.7.2 и MongoDB 4.0.
Я бы хотел использовать $ lookup, а не $ project / $ unwind, чтобы предотвратить присвоение имен каждому из возможных полей коллекции.
db.getCollection('Collection1').aggregate([
{ "$match" : { "Id" : 1 } },
{ "$lookup": {
"from": "Collection2",
"let": { collection1Id : "$Id" },
"pipeline": [
{ $match:
{ $expr:
{ $and:
[
{ $eq : [ "$Collection1Id", "$$collection2Id" ] },
{ $in : [ "$_id" , [1, 2, 3]] }
]
}
}
}
],
"as": "item"
}
}
])
Я ожидаю, что выходные данные Collection1 объединяются с Collection2 при нескольких условиях объединения.