我知道我可以通过设置特定字段以原子方式更新现有的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”}我希望用这些值更新现有的doc。我想这样做:
var update = MongoDB.Driver.Builders.Update.Merge({"favcolor":"red","favfood":"pasta"});
甚至
var update = MongoDB.Driver.Builders.Update.Merge(myUpdateBsonDoc);
其中myBsonDocument包含许多字段,我不希望从要与原始文档合并的文档中“解压缩”。
这有可能吗?
由于
答案 0 :(得分:5)
找到答案:
//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 } };
当你知道怎么做时很容易!