У меня есть две коллекции, перечисленные ниже: -
table1
{"_id" : ObjectId("5b9a.."), "item_id" :"1.1", "m_date" : "20130401","ref_id":"12R","sub_item_id":"1.1.1"}
{"_id" : ObjectId("5c37.."), "item_id" :"1.1", "m_date" : "20140401","ref_id":"12R","sub_item_id":"1.1.2"}
{"_id" : ObjectId("123cb.."), "item_id" :"1.2", "m_date" : "20140401","ref_id":"12R","sub_item_id":"1.1.3"}
table2
{"_id" : ObjectId("7cb3.."), "item_id" :"1.1", "m_date" : "20130401","ref_id":"12R","sub_item_id":"1.1.1"}
{"_id" : ObjectId("8f34.."), "item_id" :"1.1", "m_date" : "20140401","ref_id":"13R","sub_item_id":"1.1.2"}
{"_id" : ObjectId("5ec8b.."), "item_id" :"1.2", "m_date" : "20150401","ref_id":"14R","sub_item_id":"1.1.3"}
Я хотел бы отобразить поля с table1 :item_id, m_date, sub_item_id
и с table2 : ref_id
, где item_id: 1.1 Это должно быть в обеих таблицах. Ожидаемый результат должен отображать это: -
{"item_id" :"1.1", "m_date" : "20130401","sub_item_id":"1.1.1","ref_id":"12R"}
{"item_id" :"1.1", "m_date" : "20140401","sub_item_id":"1.1.2","ref_id":"13R"}
Я попытался написать запрос ниже, используя $lookup
, но нашел 0 Doc
db.table1.aggregate([
{$project:{
item_id:1,
m_date: 1,
sub_item_id : 1,
ref_id :1
}},
{
$lookup: {
from: 'table2',
localField: 'item_id',
foreignField: 'item_id',
as: 'table2_values'
},
},
{$unwind:'$table2_values'},
{ $group: {
_id: {ref_id: "$table2_values.ref_id", m_date: "$m_date"
,sub_item_id:'$sub_item_id' },
}},
{$project:{_id:0,m_date:'$_id.m_date',ref_id:'$_id.ref_id'
,sub_item_id:'$_id.sub_item_id',item_id:1}},
{
$match: {"table2_values.item_id": "1.1"}
}
])
Пожалуйста, помогите мне получить ожидаемый результат выше