sql >> Database >  >> NoSQL >> MongoDB

Update / verwijder een subdocument in mongodb met behulp van C#-stuurprogramma

Om het subdocument bij te werken, kunt u dit gebruiken:

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);

profiler:

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

En om te verwijderen:

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);

profiler:

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

Een andere manier is om het bovenliggende document bij te werken met een gewijzigde onderliggende verzameling.



  1. Laravel alle sessie-ID's met Redis-stuurprogramma

  2. Vergelijk arrays en retourneer het verschil

  3. Hoe een likes-stemsysteem te modelleren met MongoDB

  4. Voorkomen van databasegerelateerde racecondities in Node.js