आप MongoDB संग्रह में ऑब्जेक्ट सरणी में पूछे गए तत्व में फ़िल्टर करने के लिए प्रोजेक्शन ऑपरेटर $elemMatch का उपयोग कर सकते हैं। MongoDB में ऑब्जेक्ट ऐरे में केवल क्वेरी किए गए तत्व को पुनः प्राप्त करने के लिए, आइए पहले हम दस्तावेज़ ऑब्जेक्ट ऐरे के साथ एक संग्रह बनाएं।
क्वेरी इस प्रकार है:
> db.objectArray.insert({"Persons":[
{"PersonName":"Adam","PersonSalary":25000},{"PersonName":"Larry","PersonSalary":27000
}]});
WriteResult({ "nInserted" : 1 })
> db.objectArray.insert({"Persons":[
{"PersonName":"David","PersonSalary":32000},{"PersonName":"Carol","PersonSalary":77000
}]});
WriteResult({ "nInserted" : 1 }) अब आप फाइंड () की मदद से सभी दस्तावेजों को प्रदर्शित कर सकते हैं। क्वेरी इस प्रकार है:
> db.objectArray.find().pretty();
निम्न आउटपुट है:
{
"_id" : ObjectId("5c6bfadc68174aae23f5ef53"),
"Persons" : [
{
"PersonName" : "Adam",
"PersonSalary" : 25000
},
{
"PersonName" : "Larry",
"PersonSalary" : 27000
}
]
}
{
"_id" : ObjectId("5c6bfb0968174aae23f5ef54"),
"Persons" : [
{
"PersonName" : "David",
"PersonSalary" : 32000
},
{
"PersonName" : "Carol",
"PersonSalary" : 77000
}
]
} यहाँ MongoDB में किसी ऑब्जेक्ट सरणी में केवल पूछे गए तत्व को पुनः प्राप्त करने की क्वेरी है। यहां _id:0 . में आईडी प्रॉपर्टी को बाहर करने के लिए जोड़ा जाता है (_id प्रॉपर्टी न दिखाएं):
> db.objectArray.find({"Persons.PersonSalary":25000}, {
_id:0,Persons:{$elemMatch:{"PersonSalary":25000}}}).pretty(); निम्न आउटपुट है:
{
"Persons" : [
{
"PersonName" : "Adam",
"PersonSalary" : 25000
}
]
} उपरोक्त कार्य को करने का वैकल्पिक तरीका प्रोजेक्शन ऑपरेटर $. क्वेरी इस प्रकार है:
> db.objectArray.find({"Persons.PersonSalary":25000}, { _id:0,'Persons.$':1}).pretty(); निम्न आउटपुट है:
{
"Persons" : [
{
"PersonName" : "Adam",
"PersonSalary" : 25000
}
]
}