c#实现 Mongodb存储【文档局部更新】

如下:

递归更新字段  ,构建UpdateDefinition

  1.  
    /// <summary>
  2.  
    /// 构建更新操作定义
  3.  
    /// </summary>
  4.  
    /// <param name="bc">bsondocument文档</param>
  5.  
    /// <returns></returns>
  6.  
    private List<UpdateDefinition<BsonDocument>> BuildUpdateDefinition(BsonDocument bc, string parent )
  7.  
    {
  8.  
    var updates = new List<UpdateDefinition<BsonDocument>>();
  9.  
    foreach (var element in bc.Elements)
  10.  
    {
  11.  
    var key = parent == null ? element.Name : $"{parent}.{element.Name}";
  12.  
    var subUpdates = new List<UpdateDefinition<BsonDocument>>();
  13.  
    //子元素是对象
  14.  
    if (element.Value.IsBsonDocument)
  15.  
    {
  16.  
    updates.AddRange(BuildUpdateDefinition(element.Value.ToBsonDocument(), key));
  17.  
    }
  18.  
    //子元素是对象数组
  19.  
    else if (element.Value.IsBsonArray)
  20.  
    {
  21.  
    var arrayDocs = element.Value.AsBsonArray;
  22.  
    var i = 0;
  23.  
    foreach (var doc in arrayDocs)
  24.  
    {
  25.  
    if (doc.IsBsonDocument)
  26.  
    {
  27.  
    updates.AddRange(BuildUpdateDefinition(doc.ToBsonDocument(), key + $".{i}"));
  28.  
    }
  29.  
    else
  30.  
    {
  31.  
    updates.Add(Builders<BsonDocument>.Update.Set(f => f[key], element.Value));
  32.  
    continue;
  33.  
    }
  34.  
    i++;
  35.  
    }
  36.  
    }
  37.  
    //子元素是其他
  38.  
    else
  39.  
    {
  40.  
    updates.Add(Builders<BsonDocument>.Update.Set(f => f[key], element.Value));
  41.  
    }
  42.  
    }
  43.  
    return updates;
  44.  
    }

注意其中key的构建,针对文档包含的子文档,需要对其key添加到根节点的路径。针对包含文档数组的,需要添加下标,指定到对应的标签进行数据的更新。

调用更新操作,更新多份文档操作如下:

  1.  
    /// <summary>更新</summary>
  2.  
    public async Task<IEnumerable<string>> UpdateAsync(MetadataCollection metadatas)
  3.  
    {
  4.  
    List<string> result = null;
  5.  
    var kmds = metadatas.Select(e => e.As<Metadata>()).ToList();
  6.  
    var docs = kmds.ConvertAll(DicConvertToBsonDoc);
  7.  
    var updateOptions = new UpdateOptions { IsUpsert = true };
  8.  
    try
  9.  
    {
  10.  
    foreach (var doc in docs)
  11.  
    {
  12.  
    var filter = Builders<BsonDocument>.Filter.Eq(f => f[iiid], doc[iiid]);
  13.  
    var update = Builders<BsonDocument>.Update.Combine(BuildUpdateDefinition(doc,null));
  14.  
    await _access.UpdateAsync(filter, update, updateOptions);
  15.  
    }
  16.  
    result = metadatas.Select(s => s.IIId).ToList();
  17.  
    }
  18.  
    catch (Exception ex)
  19.  
    {
  20.  
    IndexExceptionCodes.UpdatingIndexFailed.ThrowUserFriendly(ex.Message, "更新索引失败");
  21.  
    }
  22.  
    return result;
  23.  
    }

其中,先将给定的模型列表转化为Mongodb的文档对象BsonDocument,然后执行更新操作。指定操作如果key不存在执行插入操作。

示例如下:

Step1:查看原文档

Step2:执行更新操作

Step3:查看更新之后的结果

参考如下:

MongoDB更新包含对象数组的元素: 使用mongodb中数组元素的下标来做更新(update)多维数组 例如有如下数据结构: {   "_id":ObjectId("4b97e62bf1d8c7152c9ccb74"),   ”comments“:[     {     "by":"joe",     "votes":3,     "replies":[                 {"by":"jane",                 "votes":2                }]      }]   }   如果要将"replies"中{“by”:"jane"}的投票数增加1,该如何做呢?
mongodb使用多维数组下标的方式来定位某个元素
先find({"comments.replies.by":"jane"})来获取到整个object, 然后计算相应reply的数组下标, 再使 用update({"comments.0.replies.0.by":"jane"},{"$inc", {"comments.0.replies.0.votes":1}})

MongoDB——更新操作(Update)c#实现的更多相关文章

  1. MySQL 的更新操作update

    1 更新操作(单表更新) 1)单表更新 update [low_priority] [ignore] table_reference set col_name1={expr1|default},col ...

  2. 事务处理操作(COMMIT,ROLLBACK)。复制表。更新操作UPDATE实际工作中一般都会有WHERE子句,否则更新全表会影响系统性能引发死机。

    更新操作时两个会话(session)同时操作同一条记录时如果没有事务处理操作(COMMIT,ROLLBACK)则会导致死锁. 复制表:此方法Oracle特有

  3. Hive扩展功能(九)--Hive的行级更新操作(Update)

    软件环境: linux系统: CentOS6.7 Hadoop版本: 2.6.5 zookeeper版本: 3.4.8 主机配置: 一共m1, m2, m3这三部机, 每部主机的用户名都为centos ...

  4. mongodb更新操作

    除了查询条件,还可以使用修改器对文档进行更新. 1. $inc > db.tianyc03.find() { "_id" : ObjectId("50ea6b6f1 ...

  5. [转]MongoDB更新操作replaceOne()实例讲解

    最近正在学习MongoDB,作为数据库的学习当然是要从CRUD开始学起了.这篇文章默认读者是知道如何安装MongoDB.如何运行MongoDB实例以及了解了MongoDB中的collection.do ...

  6. mongodb 更新操作

    db.aaaa.update({},{$push:{money:{$each:[8,9,10],$slice:-4}}}) db.aaaa.update({},{$addToSet:{money:{$ ...

  7. MongoDB 文档的更新操作

    在MongoDB中,更新单个doc的操作是原子性的.默认情况下,如果一个update操作更新多个doc,那么对每个doc的更新是原子性的,但是对整个update 操作而言,不是原子性的,可能存在前面的 ...

  8. java操作mongodb——更新数据

    Java中可以通过updateOne,updateMany,replaceOne方法进行集合的文档更新.但是 _id 是不能更新的 updateOne只会更新一条数据,即使通过Filters.lt(& ...

  9. mongodb批量更新操作文档的数组键

    persons文档的数据如下: > db.persons.find(){ "_id" : 2, "name" : 2 }{ "_id" ...

随机推荐

  1. matplotlib 操作子图(subplot,axes)

    Matplotlib 中文用户指南 3.3 使用 GridSpec 自定义子图位置 ax:matplotlib.axes._subplots.AxesSubplot,的基本操作 ax.set_xtic ...

  2. .NET练习计算平方根

    1.新建Windows窗体 2.窗体中添加控件:TextBox(文本框).Button(按钮).和Label(标签) 3.为Button对象添加点击事件代码 点击事件代码设计思路 ①从文本框中获取输入 ...

  3. 服务器购买+建站流程教程——适合新手没有经验的人Chinar总结

    服务器购买购买教程 本文提供全图文流程,中文翻译. Chinar 坚持将简单的生活方式,带给世人!(拥有更好的阅读体验 -- 高分辨率用户请根据需求调整网页缩放比例) Chinar -- 心分享.心创 ...

  4. Appium笔记(一) 丶Appium的自我介绍

    一.我是谁,我的特点是什么 Appium是一款开源测试自动化框架,可用于原生.混合和移动Web应用程序.它使用WebDriver协议驱动iOS,Android和Windows应用程序.重要的是,App ...

  5. javascript的单例模式

    单例模式是javascript最基本,最有用的模式之一,它提供了一种将代码组织为一个逻辑单元的手段,这个逻辑单元中的代码通过单一的变量进行访问.我的理解是在这个作用域中,只有通过单一的变量来访问,不存 ...

  6. UVA10003 【Cutting Sticks】

    [分析] 设d(i,j)为切割小木棍i-j的最优费用,则d(i,j)=min{d(i,k)+d(k,j)|i<k<j}+a[j]-a[i],其 中最后一项a[j]-a[i]代表第一刀的费用 ...

  7. USB速率识别

    低速设备D-上有一个1.5k欧的上拉电阻.高速和全速设别在D+上有一1.5k欧上拉电阻.连接后通过检测电压变化来了解设备是否为低速设别. 低速下:D+为“0”,D-为“1”是为“J”状态,“K”状态相 ...

  8. solrcloud配置中文分词器ik

    无论是solr还是luncene,都对中文分词不太好,所以我们一般索引中文的话需要使用ik中文分词器. 三台机器(192.168.1.236,192.168.1.237,192.168.1.238)已 ...

  9. dbt 包管理

    dbt 可以方便的支持基于git 的包管理 依赖申明 位置 dbt_project.yml 中的repositories 或者使用packages.yaml 格式 dbt_project.yml: r ...

  10. All the Apache Streaming Projects: An Exploratory Guide

    The speed at which data is generated, consumed, processed, and analyzed is increasing at an unbeliev ...