হ্যাঁ, MongoDB-এর সাথে অ্যারের একটি অবজেক্টে একটি ক্ষেত্রের জন্য অনুসন্ধান করতে, নিম্নলিখিত সিনট্যাক্স ব্যবহার করুন -
db.yourCollectionName.find({"yourOuterFieldName": { $elemMatch: { "yourInnerFieldName": "yourValue" } } } ).pretty(); উপরের ধারণাটি বুঝতে, আসুন ডকুমেন্টের সাথে একটি সংগ্রহ তৈরি করি। একটি নথির সাথে একটি সংগ্রহ তৈরি করার প্রশ্নটি নিম্নরূপ -
> db.objectInAnArrayDemo.insertOne({ "StudentDetails": [{
"StudentName": "John", "StudentMessage": "Hi"}, {"StudentName": "Larry", "StudentMessage": "Hello"}]})
{
"acknowledged" : true,
"insertedId" : ObjectId("5c92635d36de59bd9de06381")
}
> db.objectInAnArrayDemo.insertOne({ "StudentDetails": [{
"StudentName": "Carol", "StudentMessage": "Hello"}, {"StudentName": "David", "StudentMessage": "Good Morning"}]})
{
"acknowledged" : true,
"insertedId" : ObjectId("5c92637936de59bd9de06382")
} Find() পদ্ধতির সাহায্যে একটি সংগ্রহ থেকে সমস্ত নথি প্রদর্শন করুন। প্রশ্নটি নিম্নরূপ -
> db.objectInAnArrayDemo.find().pretty();
নিচের আউটপুট −
{
"_id" : ObjectId("5c92635d36de59bd9de06381"),
"StudentDetails" : [
{
"StudentName" : "John",
"StudentMessage" : "Hi"
},
{
"StudentName" : "Larry",
"StudentMessage" : "Hello"
}
]
}
{
"_id" : ObjectId("5c92637936de59bd9de06382"),
"StudentDetails" : [
{
"StudentName" : "Carol",
"StudentMessage" : "Hello"
},
{
"StudentName" : "David",
"StudentMessage" : "Good Morning"
}
]
} এখানে MongoDB −
এর সাথে অ্যারের একটি অবজেক্টের একটি ক্ষেত্রের জন্য ক্যোয়ারী রয়েছে> db.objectInAnArrayDemo.find({"StudentDetails": { $elemMatch: { "StudentMessage": "Good Morning" } } } ).pretty(); নিচের আউটপুট −
{
"_id" : ObjectId("5c92637936de59bd9de06382"),
"StudentDetails" : [
{
"StudentName" : "Carol",
"StudentMessage" : "Hello"
},
{
"StudentName" : "David",
"StudentMessage" : "Good Morning"
}
]
}