sql >> Databasteknik >  >> NoSQL >> MongoDB

Uppdatera/ta bort ett underdokument i mongodb med C#-drivrutinen

För att uppdatera underdokument kan du använda detta:

var update = Update.Set("AnswerList.$.OptionName", "new").Set("AnswerList.$.VoteCount", 5);
collection.Update(Query.And(Query.EQ("_id", new BsonObjectId("50f3c313f216ff18c01d1eb0")), Query.EQ("AnswerList.OptionId", "1")), update);

profilerare:

"query" : { "_id" : ObjectId("50f3c313f216ff18c01d1eb0"), "AnswerList.OptionId" : "1" },
"updateobj" : { "$set" : { "AnswerList.$.OptionName" : "new", "AnswerList.$.VoteCount" : 5 } }

Och för att ta bort:

var pull = Update<Vote>.Pull(x => x.AnswerList, builder => builder.EQ(q => q.OptionId, "2"));
collection.Update(Query.And(Query.EQ("_id", new BsonObjectId("50f3c313f216ff18c01d1eb0")), Query.EQ("AnswerList.OptionId", "2")), pull);

profilerare:

"query" : { "_id" : ObjectId("50f3c313f216ff18c01d1eb0"), "AnswerList.OptionId" : "2" },
"updateobj" : { "$pull" : { "AnswerList" : { "OptionId" : "2" } } }

Ett annat sätt är att uppdatera överordnat dokument med modifierad underordnad samling.



  1. Projektionsmöjlighet för att returnera fältets längd/storlek

  2. koppla mongodb med djongo (Django)

  3. Punktnotation kontra $elemMatch

  4. Hur man installerar Apache CouchDB 2.3.0 i Linux