MongoDB-তে $unwind প্রতিটি উপাদানের জন্য একটি নথি আউটপুট করতে ইনপুট নথি থেকে একটি অ্যারে ক্ষেত্রকে বিনির্মাণ করে।
$group নির্দিষ্ট _id এক্সপ্রেশন দ্বারা ইনপুট নথিগুলিকে গ্রুপ করতে ব্যবহৃত হয় এবং প্রতিটি স্বতন্ত্র গ্রুপিংয়ের জন্য একটি নথি আউটপুট করে৷
অনুরোধ করা ক্ষেত্রগুলির সাথে নথিগুলিকে পাইপলাইনের পরবর্তী পর্যায়ে যাওয়ার জন্য $project ব্যবহার করা হয়৷
আসুন আমরা নথি-
সহ একটি সংগ্রহ তৈরি করি> db.demo238.insertOne( ... { ... ... "EmailId" : "[email protected]", ... "details" : [ ... { ... "Name" : "Bob", ... "isActive" : true ... } ... ] ... } ...); { "acknowledged" : true, "insertedId" : ObjectId("5e4418e3f4cebbeaebec5152") } > > db.demo238.insertOne( ... { ... ... "EmailId" : "[email protected]", ... "details" : [ ... { ... "Name" : "David" ... } ... ] ... } ...); { "acknowledged" : true, "insertedId" : ObjectId("5e4418e3f4cebbeaebec5153") } > > > db.demo238.insertOne( ... { ... ... "EmailId" : "[email protected]", ... "details" : [ ... { ... "Name" : "Carol", ... "isActive" : true ... } ... ] ... } ...); { "acknowledged" : true, "insertedId" : ObjectId("5e4418e4f4cebbeaebec5154") }
Find() পদ্ধতির সাহায্যে একটি সংগ্রহ থেকে সমস্ত নথি প্রদর্শন করুন:
> db.demo238.find().pretty();
এটি নিম্নলিখিত আউটপুট −
তৈরি করবে{ "_id" : ObjectId("5e4418e3f4cebbeaebec5152"), "EmailId" : "[email protected]", "details" : [ { "Name" : "Bob", "isActive" : true } ] } { "_id" : ObjectId("5e4418e3f4cebbeaebec5153"), "EmailId" : "[email protected]", "details" : [ { "Name" : "David" } ] } { "_id" : ObjectId("5e4418e4f4cebbeaebec5154"), "EmailId" : "[email protected]", "details" : [ { "Name" : "Carol", "isActive" : true } ] }
MongoDB এগ্রিগেট বাস্তবায়নের জন্য নিম্নোক্ত ক্যোয়ারী - unwind, group and project −
> db.demo238.aggregate( ... [ ... { "$match": { "details.isActive": true } }, ... { "$unwind": "$details" }, ... { "$match": { "details.isActive": true } }, ... { "$group": { ... "_id": "$details.Name", ... "active": { "$first": "$_id" } ... }} ... ], ... function(err,result) { ... ... } ...);
এটি নিম্নলিখিত আউটপুট −
তৈরি করবে{ "_id" : "Carol", "active" : ObjectId("5e4418e4f4cebbeaebec5154") } { "_id" : "Bob", "active" : ObjectId("5e4418e3f4cebbeaebec5152") }