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"
      }
   ]
}

更新于:2020 年 3 月 30 日

517 次浏览

启动您的 职业

通过完成课程获得认证

入门
广告
© . All rights reserved.