MongoDB
 sql >> डेटाबेस >  >> NoSQL >> MongoDB

MongoDB एक सरणी के भीतर सरणी वस्तु को अद्यतन कर रहा है

आप $[] . का उपयोग कर सकते हैं positional-all नेस्टेड सरणी तत्वों को अपडेट करने के लिए, $[]

क्वेरी

db.t14.update(
   {},
   { $set: { "calc.$[].datasets.$[elem].name": "updated" } },
   { arrayFilters: [  { "elem": "x1" } ], multi: true}
)

दस्तावेज़ के साथ नमूना संग्रह

> db.t14.findOne()
{
        "_id" : 1,
        "calc" : [
                {
                        "preset" : "abc",
                        "datasets" : [
                                {
                                        "_id" : "x1",
                                        "name" : "n1"
                                },
                                {
                                        "_id" : "x2",
                                        "name" : "n2"
                                }
                        ]
                }
        ]
}

अपडेट करें

> db.t14.update({},{$set: { "calc.$[].datasets.$[elem].name": "newname" } },{ arrayFilters: [{ "elem.name": "n1" }], multi: true})
WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 })

अपडेट पोस्ट करें

> db.t14.findOne()
{
        "_id" : 1,
        "calc" : [
                {
                        "preset" : "abc",
                        "datasets" : [
                                {
                                        "_id" : "x1",
                                        "name" : "newname"
                                },
                                {
                                        "_id" : "x2",
                                        "name" : "n2"
                                }
                        ]
                }
        ]
}
>



  1. Redis
  2.   
  3. MongoDB
  4.   
  5. Memcached
  6.   
  7. HBase
  8.   
  9. CouchDB
  1. मोंगो डीबी - JSON विस्तारित मोड में निर्यात करें

  2. नेवला स्कीमा में नेस्टेड ऑब्जेक्ट

  3. MongoDB _id की सरणी में कहां चुनें?

  4. MongoDB $setIntersection

  5. उल्का में समग्र कार्य का उपयोग कैसे करें