c# - 如何使用 .NET 的 MongoDB 驱动程序的 updateOne() 更新但不替换文档
问题描述
情况:
我在 MongoDB 中有一个现有的文档集合,我想在其中使用传入文档的字段更新特定文档的字段。传入文档与集合中的文档具有相同的类,但并非所有字段都已设置,即某些字段为空。现在,我不想替换集合中的整个文档,也不想替换所有字段,但我只想替换那些不为空的字段,其余的保持原样。
这个 SO 答案描述了如何替换整个文档。我用这个代码得到了这个:
public void Update(string id, MyDoc docIn) => _docs.ReplaceOne(doc => scan.Id.Equals(ObjectId.Parse(id)), docIn);
为了更新文档中的各个字段,文档建议创建一个 "Update Operator Expressions Document"。
我的问题:
这是否意味着我必须编写自己的函数将传入的文档变成这样的“更新运算符表达式文档”,还是有更方便的方法?
解决方案
正如您已经说过的,使用更新运算符是要走的路。
这个想法是使用过滤器并使用通过属性的对象的反射。
您可以根据需要修改更新和过滤功能。
using System.Reflection;
public void Update(string id, MyDoc docIn)
=> _docs.UpdateOne(doc => doc.Id.Equals(ObjectId.Parse(id)), UpdateDocument(docIn);
public UpdateDefinition<myDoc> UpdateDocument(myDoc docIn)
{
var builder = Builders<MyDoc>.Update.Set(u => u.Id, docIn.Id);
foreach(PropertyInfo prop in docIn.GetType().GetProperties())
{
var value = docIn.GetType().GetProperty(prop.Name).GetValue(docIn,null);
if ((prop.Name != "Id") & (value != null))
{
builder = builder.Set(prop.Name, value);
}
}
return builder;
}
推荐阅读
- php - yii2 使用查询字符串数组创建链接
- javascript - 用于抓取图像的无头 chrome 最大限度地利用 CPU(即 100%)
- javascript - Jest Test 中的触发事件不调用 Method
- swift - 相同的cornerRadius 在视图下方可见
- xslt - 如何在xslt中使用大于和小于
- powershell - Clear-RecycleBin cmdlet 的进度条输出显示不正确
- c# - 在 VS 2019 winform c# 中没有获得浮点值到水晶报告
- git - Git问题:两个类似的源代码/项目副本的分支或新存储库
- performance - og:image 是在标准浏览器会话期间下载的吗?(又名它会影响性能吗?)
- python - 如何以 PDF 格式保存 Selenium (Python)