У меня есть кусок кода, чтобы присоединить коллекцию A (образец) к коллекции B (локаторы).Я пробовал синтаксис $unwind
, $group
и $push
, единственная проблема в том, что я не могу вернуть поле locator
и record
.
data = db.sample.aggregate([
{'$lookup': {
'from': 'locators',
'localField': "locator",
'foreignField': "_id",
'as': "metalocator"}}])
print(list(data))
, котороевозвращает
[
{
'_id': '599A65E1A80541BA',
'locator': 'ABC',
'record': 'Nicaragua',
'metalocator': [{'_id': 'ABC', 'group': 'Location', 'section': 'Geo', 'cabinet': 'Country', 'record': 'string', 'status': 'integer'}]
},
{
'_id': '428E970995AE8C76',
'locator': 'CDE',
'record': 'Nigeria',
'metalocator': [{'_id': 'CDE', 'group': 'Location', 'section': 'Geo', 'cabinet': 'Country', 'record': 'string', 'status': 'integer'}]
}
]
попытка 1
data = db.sample.aggregate([
{"$lookup": {"from": "locators",
"localField": "locator",
"foreignField": "_id",
"as": "metalocator"}},
{"$unwind": '$metalocator'},
{"$group": {"_id": "$_id",
"metalocator": {"$push": {
"section": "$metalocator.section",
"cabinet": "$metalocator.cabinet"}}}}
])
print(list(data))
Что возвращает:
[
{
'_id': '1835853D2982AAEF',
'metalocator': [{'section': 'Geo', 'cabinet': 'Country'}]
},
{
'_id': '428E970995AE8C76',
'metalocator': [{'section': 'Geo', 'cabinet': 'Country'}]
}
]
Ожидаемый результат должен быть:
[
{
'_id': '1835853D2982AAEF',
'locator': 'ABC',
'record': 'Nicaragua',
'metalocator': [{'section': 'Geo', 'cabinet': 'Country'}]
},
{
'_id': '428E970995AE8C76',
'locator': 'CDE',
'record': 'Nigeria',
'metalocator': [{'section': 'Geo', 'cabinet': 'Country'}]
}
]