Computer >> कंप्यूटर >  >> प्रोग्रामिंग >> Mongodb

कई उप-दस्तावेजों से फ़ील्ड प्राप्त करें जो MongoDB में किसी शर्त से मेल खाते हैं?

<घंटा/>

एकाधिक उप-दस्तावेज़ों से फ़ील्ड प्राप्त करने के लिए, $unwind के साथ MongoDB समुच्चय का उपयोग करें। आइए दस्तावेजों के साथ एक संग्रह बनाएं -

> db.demo671.insertOne(
... {
...
...    "details" : [
...    {
...       "id" : "1"
...    },
...    {
...       CountryName:"US",
...       "details1" : [
...       {
...       "id" : "1"
...       },
...       {
...          "id" : "2"
...       }
...       ]
...    },
... {
...    CountryName:"UK",
...    "details1" : [
...    {
...       "id" : "2"
...    },
...    {
...       "id" : "1"
...    }
...    ]
... },
... {
...    CountryName:"AUS",
...    "details1" : [
...       {
...          "id" : "1"
...       }
...       ]
...    }
... ]
... }
... )
{
   "acknowledged" : true,
   "insertedId" : ObjectId("5ea3e5d004263e90dac943e0")
}

संग्रह से सभी दस्तावेज़ों को खोजने () विधि की सहायता से प्रदर्शित करें -

> db.demo671.find();

यह निम्नलिखित आउटपुट उत्पन्न करेगा -

{ "_id" : ObjectId("5ea3e5d004263e90dac943e0"), "details" : [ { "id" : "1" }, { "CountryName" : "US", "details1" : [ { "id" : "1" }, { "id" : "2" } ] }, { "CountryName" : "UK", "details1" : [ { "id" : "2" }, { "id" : "1" } ] }, { "CountryName" : "AUS", "details1" : [ { "id" : "1" } ] } ] }

यहां कई उप-दस्तावेजों से फ़ील्ड प्राप्त करने की क्वेरी है जो MongoDB में एक शर्त से मेल खाते हैं -

> db.demo671.aggregate([
...
...   {$unwind: '$details'},
...
...   {$match: {'details.details1.id': '1'}},
...
...   {$project: {_id: 0, Country: '$details.CountryName'}}
... ]).pretty()

यह निम्नलिखित आउटपुट उत्पन्न करेगा -

{ "Country" : "US" }
{ "Country" : "UK" }
{ "Country" : "AUS" }

  1. MongoDB से फ़ील्ड का सबसेट पुनर्प्राप्त करना

    फ़ील्ड के सबसेट को फिर से आज़माने के लिए, फ़ाइंड () में डॉट नोटेशन का उपयोग करें। आइए दस्तावेजों के साथ एक संग्रह बनाएं - > db.demo307.insertOne({ ...   "CleintId":101, ...   "ClientDetails":{"ClientFirstName":"Chris","Age":34}, ... &nbs

  1. एकाधिक दस्तावेज़ फ़ील्ड पर सटीक मिलान के लिए MongoDB क्वेरी

    सटीक मिलान के लिए, मान को MongoDB $in() के अंदर मिलान करने के लिए सेट करें। आइए पहले दस्तावेजों के साथ एक संग्रह बनाएं - > db.demo422.insertOne({"Name":"Chris","Marks":34}); {    "acknowledged" : true,    "insertedId" : ObjectI

  1. MongoDB एकत्रीकरण के साथ कई क्षेत्रों द्वारा गणना करें

    एकाधिक फ़ील्ड द्वारा गिनने के लिए, MongoDB में $facet का उपयोग करें। $facet इनपुट दस्तावेज़ों के एक ही सेट पर एक ही चरण में कई एकत्रीकरण पाइपलाइनों को संसाधित करता है। आइए दस्तावेजों के साथ एक संग्रह बनाएं - db.demo721.insertOne(... {...... details1:{... id:101......},. .. details2:{... id:102...},