sql >> Database teknologi >  >> NoSQL >> MongoDB

Opdater/slet et underdokument i mongodb ved hjælp af C#-driver

For at opdatere underdokument kan du bruge dette:

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 } }

Og for at fjerne:

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" } } }

En anden måde er at opdatere overordnet dokument med ændret underordnet samling.



  1. Grunt Serve-ur kaster EBUSY-advarsel over mongod.lock

  2. Hvordan ændrer man typen af ​​et felt?

  3. Sådan holder du øje med ændringer til specifikke felter i MongoDB change stream

  4. MongoDB listeprojektion af underfelt