MongoDB 如何集合 JSON 陣列欄位來匹配其他集合的欄位?
為此,建立兩個集合並新增一些文件。之後,使用 $lookup 進行匹配。我們使用文件建立集合,如下所示:-
> db.demo101.insertOne(
... { "_id" : "1", "Details" : [ { "PId" : "200" }, { "PId" : "201" }, { "PId" : "201" } ] }
... )
{ "acknowledged" : true, "insertedId" : "1" }使用 find() 方法顯示集合中的所有文件,如下所示:-
> db.demo101.find();
這將生成以下輸出:-
{ "_id" : "1", "Details" : [ { "PId" : "200" }, { "PId" : "201" }, { "PId" : "201" } ] }以下是使用一些文件建立第二個集合的查詢:-
> db.demo102.insertOne(
... { "_id" : "201", "CustEmailId" : "Carol@gmail.com" }
... );
{ "acknowledged" : true, "insertedId" : "201" }使用 find() 方法顯示集合中的所有文件,如下所示:-
> db.demo102.find();
這將生成以下輸出:-
{ "_id" : "200", "CustEmailId" : "John@gmail.com" }
{ "_id" : "201", "CustEmailId" : "Carol@gmail.com" }以下是集合 JSON 陣列欄位與其他集合的匹配欄位進行聚合的查詢:-
> db.demo101.aggregate(
... [
... {$unwind:"$Details"},
... {$lookup : {from : "demo102", "localField":"Details.PId", "foreignField":"_id", as :"out"}},
... {$project : {"_id":1, "Details.PId":{$arrayElemAt:["$out.CustEmailId",0]}}},
... {$group:{_id:"$_id", Details : {$push : "$Details"}}}
... ]
... ).pretty()這將生成以下輸出:-
{
"_id" : "1",
"Details" : [
{
"PId" : "John@gmail.com"
},
{
"PId" : "Carol@gmail.com"
},
{
"PId" : "Carol@gmail.com"
}
]
}
廣告
資料結構
網路
關係型資料庫管理系統
作業系統
Java
iOS
HTML
CSS
Android
Python
C 程式設計
C++
C#
MongoDB
MySQL
Javascript
PHP