MongoDB-তে একাধিক নথি মার্জ করতে, aggregate() ব্যবহার করুন। আসুন আমরা নথি-
সহ একটি সংগ্রহ তৈরি করি> db.demo436.insertOne(
... {
... "_id" : "101",
... "Name": "Chris",
... "details" : [
... {
... "CountryName" : "US",
... "Age" : 21
... }
... ],
... "Price" : 50
... }
... );
{ "acknowledged" : true, "insertedId" : "101" }
> db.demo436.insertOne(
... {
... "_id" : "102",
... "Name": "Chris",
... "details" : [
... {
... "CountryName" : "UK",
... "Age" : 22
... }
... ],
... "Price" : 78
... }
... );
{ "acknowledged" : true, "insertedId" : "102" }
> db.demo436.insertOne(
... {
... "_id" : "103",
... "Name": "Chris",
... "details" : [
... {
... "CountryName" : "US",
... "Age" : 21
... }
... ],
.. . "Price" : 50
... }
... );
{ "acknowledged" : true, "insertedId" : "103" } Find() পদ্ধতি -
এর সাহায্যে একটি সংগ্রহ থেকে সমস্ত নথি প্রদর্শন করুন> db.demo436.find();
এটি নিম্নলিখিত আউটপুট −
তৈরি করবে{ "_id" : "101", "Name" : "Chris", "details" : [ { "CountryName" : "US", "Age" : 21 } ], "Price" : 50 }
{ "_id" : "102", "Name" : "Chris", "details" : [ { "CountryName" : "UK", "Age" : 22 } ], "Price" : 78 }
{ "_id" : "103", "Name" : "Chris", "details" : [ { "CountryName" : "US", "Age" : 21 } ], "Price" : 50 } MongoDB −
-এ একাধিক নথি মার্জ করার জন্য নিচের প্রশ্নটি রয়েছে> db.demo436.aggregate([
... {$sort: {_id: 1, Name: 1}},
... {$unwind: '$details'},
... {$group: {_id: '$Name', details: {$push: '$details'},
... Price: {$sum: '$Price'},
... id: {$last: {$concat: ["$_id", "_", "AppendedValue" ]}},
... Name: {$last: '$Name'}}},
... {$addFields: {Id: 'NewIdAppped', _id: '$id'}},
... {$project: {"id": 0 }}]) এটি নিম্নলিখিত আউটপুট −
তৈরি করবে{ "_id" : "103_AppendedValue", "details" : [ { "CountryName" : "US", "Age" : 21 }, { "CountryName" : "UK", "Age" : 22 }, { "CountryName" : "US", "Age" : 21 } ], "Price" : 178, "Name" : "Chris", "Id" : "NewIdAppped" }