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

标签 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"} 我想用这些值更新现有文档。我想这样做:

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/

相关文章:

javascript - 如何从 Mongodb 中删除数组元素

node.js - 未处理的 promise 拒绝警告 : Mongoose Server Selection Error

node.js - MongoDB 返回结果的关联数组

mongodb - 在 mongoDB 中,函数 AddToSet 添加重复项

c# - 在不创建查询对象的情况下使用 C# Mongo 驱动程序进行查询?

c# - C# MongoDB Driver 按之前插入的方式获取数据顺序列表

mongodb - Mongo shell 无法连接到 Azure CosmosDB

MongoDB C# 删除不起作用

c# - 如何使用 .NET 的 MongoDB 驱动程序的 updateOne() 更新但不替换文档

mongodb-.net-driver - BsonClassMapSerializer 已经注册了 AbstractClassSerializer