หากต้องการรวมเอกสารที่ซ้อนกันใน MongoDB คุณสามารถใช้ $group ให้เราสร้างคอลเลกชันที่มีเอกสารก่อน -
> db.aggregateDemo.insertOne( ... { ... "ProductInformation": [ ... { ... "Product1": [ ... { ... Amount: 50 ... }, ... { ... Amount: 90 ... }, ... { ... Amount: 30 ... } ... ] ... }, ... { ... "Product1": [ ... { ... Amount: 200 ... }, ... { ... Amount: 30 ... }, ... { ... Amount: 40 ... } ... ] ... }, ... { ... "Product1": [ ... { ... Amount: 150 ... }, ... { ... Amount: 190 ... }, ... { ... Amount: 198 ... } ... ] ... } ... ... ] ... }); { "acknowledged" : true, "insertedId" : ObjectId("5e04df58150ee0e76c06a04d") } > db.aggregateDemo.insertOne( ... { ... "ProductInformation": [ ... { ... "Product1": [ ... { ... Amount: 100 ... }, ... { ... Amount: 1002 ... }, ... { ... Amount: 78 ... } ... ] ... }, ... { ... "Product1": [ ... { ... Amount: 75 ... }, ... { ... Amount: 400 ... }, ... { ... Amount: 600 ... } ... ] ... }, ... { ... "Product1": [ ... { ... Amount: 700 ... }, ... { ... Amount: 500 ... }, ... { ... Amount: 600 ... } ... ] ... } ... ... ] ... }); { "acknowledged" : true, "insertedId" : ObjectId("5e04df93150ee0e76c06a04e") }
ต่อไปนี้เป็นแบบสอบถามเพื่อแสดงเอกสารทั้งหมดจากคอลเลกชันโดยใช้วิธี find() -
> db.aggregateDemo.find().pretty();
สิ่งนี้จะสร้างผลลัพธ์ต่อไปนี้ -
{ "_id" : ObjectId("5e04df58150ee0e76c06a04d"), "ProductInformation" : [ { "Product1" : [ { "Amount" : 50 }, { "Amount" : 90 }, { "Amount" : 30 } ] }, { "Product1" : [ { "Amount" : 200 }, { "Amount" : 30 }, { "Amount" : 40 } ] }, { "Product1" : [ { "Amount" : 150 }, { "Amount" : 190 }, { "Amount" : 198 } ] } ] } { "_id" : ObjectId("5e04df93150ee0e76c06a04e"), "ProductInformation" : [ { "Product1" : [ { "Amount" : 100 }, { "Amount" : 1002 }, { "Amount" : 78 } ] }, { "Product1" : [ { "Amount" : 75 }, { "Amount" : 400 }, { "Amount" : 600 } ] }, { "Product1" : [ { "Amount" : 700 }, { "Amount" : 500 }, { "Amount" : 600 } ] } ] }
นี่คือแบบสอบถามเพื่อรวมเอกสารที่ซ้อนกัน -
> db.aggregateDemo.aggregate([ ... { ... $unwind:"$ProductInformation" ... }, ... { ... $unwind:"$ProductInformation.Product1" ... }, ... { ... $group:{ ... _id:null, ... MaximumAmount:{ ... $max:"$ProductInformation.Product1.Amount" ... } ... } ... } ... ]);
สิ่งนี้จะสร้างผลลัพธ์ต่อไปนี้ -
{ "_id" : null, "MaximumAmount" : 1002 }