通过'merge'文件进行MongoDB原子更新

时间:2011-05-11 13:37:18

标签: mongodb mongodb-.net-driver

我知道我可以通过设置特定字段以原子方式更新现有的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包含许多字段,我不希望从要与原始文档合并的文档中“解压缩”。

这有可能吗?

由于

1 个答案:

答案 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 } };

当你知道怎么做时很容易!