একটি অ্যারের উপর ভিত্তি করে নথি ফিল্টার করতে, $elemMatch ব্যবহার করুন৷ $elemMatch অপারেটর এমন নথির সাথে মেলে যাতে একটি অ্যারে ক্ষেত্র রয়েছে৷
৷আসুন আমরা নথি সহ একটি সংগ্রহ তৈরি করি -
> db.demo453.insertOne( ... { _id: 101, details: [ { Name: "David", Marks: 60 }, { Name: "Mike", Marks: 55} ] } ... ) { "acknowledged" : true, "insertedId" : 101 } > db.demo453.insertOne( ... { _id: 102, details: [ { Name: "Bob", Marks: 80 }, { Name: "Sam", Marks: 78} ] } ... ) { "acknowledged" : true, "insertedId" : 102 } > db.demo453.insertOne( ... { _id: 103, details: [ { Name: "Carol", Marks: 67 }, { Name: "John", Marks: 79} ] } ... ) { "acknowledged" : true, "insertedId" : 103 }
Find() পদ্ধতি -
এর সাহায্যে একটি সংগ্রহ থেকে সমস্ত নথি প্রদর্শন করুন> db.demo453.find();
এটি নিম্নলিখিত আউটপুট −
তৈরি করবে{ "_id" : 101, "details" : [ { "Name" : "David", "Marks" : 60 }, { "Name" : "Mike", "Marks" : 55 } ] } { "_id" : 102, "details" : [ { "Name" : "Bob", "Marks" : 80 }, { "Name" : "Sam", "Marks" : 78 } ] } { "_id" : 103, "details" : [ { "Name" : "Carol", "Marks" : 67 }, { "Name" : "John", "Marks" : 79 } ] }
একটি অ্যারের উপর ভিত্তি করে ডকুমেন্ট ফিল্টার করার জন্য ক্যোয়ারী −
> db.demo453.find( ... { details: { $elemMatch: {Marks: { $gte: 75 } } } } ... )
এটি নিম্নলিখিত আউটপুট −
তৈরি করবে{ "_id" : 102, "details" : [ { "Name" : "Bob", "Marks" : 80 }, { "Name" : "Sam", "Marks" : 78 } ] } { "_id" : 103, "details" : [ { "Name" : "Carol", "Marks" : 67 }, { "Name" : "John", "Marks" : 79 } ] }