MongoDB
 Computer >> コンピューター >  >> プログラミング >> MongoDB

MongoDBは、他のコレクションの一致するフィールドのJSON配列フィールドを集約しますか?


このために、2つのコレクションを作成し、いくつかのドキュメントを追加します。その後、$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" } ] }

以下は、いくつかのドキュメントを使用して2番目のコレクションを作成するためのクエリです-

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

  1. MongoDBでコレクションとグループ化をフィールド数で集計するにはどうすればよいですか?

    MongoDBのaggregate()で、$groupとaggregatecollectionを使用します。ドキュメントを使用してコレクションを作成しましょう- > db.demo616.insertOne({"details":{"Name":"Chris","Age":21}}); {    "acknowledged" : true,    "insertedId" : ObjectId("5e99bfac6549

  2. MongoDBコレクション内のすべてのドキュメントに新しいフィールドを追加する方法

    新しいフィールドを追加するには、MongoDBで$addFieldsを使用します。ドキュメントを使用してコレクションを作成しましょう- > db.demo712.insertOne({"Name":"John"}); {    "acknowledged" : true,    "insertedId" : ObjectId("5ea85f675d33e20ed1097b82") } > db.demo712.insertOne({"