我知道我可以通过设置特定字段自动更新现有的 Mongo 文档。以下代码将执行此操作:
var update = MongoDB.Driver.Builders.Update.Set("InsideLegMeasurement", 32.4);
SafeModeResult result = personCollection.Update(query, update, UpdateFlags.Multi,SafeMode.True);
但是,我可以通过传入一个我想与现有文档“合并”的文档来自动更新多个字段吗?假设我有一个文件如下: {"favcolor":"red","favfood":"pasta"} 我想用这些值更新现有文档。我想这样做:
var update = MongoDB.Driver.Builders.Update.Merge({"favcolor":"red","favfood":"pasta"});
甚至
var update = MongoDB.Driver.Builders.Update.Merge(myUpdateBsonDoc);
其中 myBsonDocument 包含许多字段,我不想从要与原始文档合并的文档中“解压”这些字段。
这有可能吗?
谢谢
最佳答案
找到答案:
//var snippetJSON= '{title:"Tin Machine II",brandnewfield:"this gets added nicely"}';
MongoDB.Bson.BsonDocument updateDoc = MongoDB.Bson.Serialization.BsonSerializer.Deserialize<BsonDocument>(snippetJSON);
var update = new UpdateDocument { { "$set", updateDoc } };
知道怎么做就很容易!
关于通过 'merge' 文档进行 MongoDB 原子更新,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5965181/