ফিল্টার এবং আনতে, MongoDB $filter এবং $match সহ প্রজেকশন ব্যবহার করুন। আসুন নথি-
সহ একটি সংগ্রহ তৈরি করি> db.demo507.insertOne( ... { ... ... "Information": ... [ ... {"Name":"John","SubjectName":"MySQL"}, ... {"Name":"Bob","SubjectName":"MongoDB"}, ... {"Name":"Chris","SubjectName":"MySQL"}, ... {"Name":"David","SubjectName":"C++"} ... ] ... } ... ); { "acknowledged" : true, "insertedId" : ObjectId("5e8836d3987b6e0e9d18f577") }
Find() পদ্ধতি -
এর সাহায্যে একটি সংগ্রহ থেকে সমস্ত নথি প্রদর্শন করুন> db.demo507.find().pretty();
এটি নিম্নলিখিত আউটপুট −
তৈরি করবে{ "_id" : ObjectId("5e8836d3987b6e0e9d18f577"), "Information" : [ { "Name" : "John", "SubjectName" : "MySQL" }, { "Name" : "Bob", "SubjectName" : "MongoDB" }, { "Name" : "Chris", "SubjectName" : "MySQL" }, { "Name" : "David", "SubjectName" : "C++" } ] }
অবজেক্ট-
-এ কিছু ক্ষেত্র ফিল্টার করার জন্য নিচের প্রশ্নটি রয়েছে> db.demo507.aggregate([ ... {$match: {"Information.SubjectName" : "MySQL" } }, ... {$project: { ... _id:0, ... Information: { ... $filter: { ... input: '$Information', ... as: 'result', ... cond: {$eq: ['$$result.SubjectName', 'MySQL']} ... } ... } ... } ... },{$project: {Information: { SubjectName:1}}} ... ]);
এটি নিম্নলিখিত আউটপুট −
তৈরি করবে{ "Information" : [ { "SubjectName" : "MySQL" }, { "SubjectName" : "MySQL" } ] }