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. UI基础:target...action设计模式,手势识别器.UIimageview

    使用target..action和delegate设计模式可以实现解耦.使代码更加优化. 手势识别器: 手势识别器:是对触摸事件做了封装,无需自己去判断某个手势是否触发,手势识别器本身起到了识别作用, ...

  2. paho.mqtt.embedded-c MQTTPacket transport.c hacking

    /******************************************************************************* * paho.mqtt.embedde ...

  3. MySQL设置默认编码

    查看默认编码:show variables like "char%" MySQL5.5以下版本: 1.打开配置文件 2.在[client]和[mysqld]字段下面均添加defau ...

  4. device public set

    backgroud:  our dvertiser provide on device list of idfa to show ad to  target audience,however none ...

  5. stenciljs 学习三 组件生命周期

    stenciljs 组件包含好多生命周期方法, will did load update unload 实现生命周期的方法比价简单类似 componentWillLoad ....,使用typescr ...

  6. greasemonkey修改网页url

    // ==UserScript== // @name JSHE_ModifyFunction // @namespace jshe // @include http://localhost/* // ...

  7. maven 知识点2

    maven 命令: table th:first-of-type { width: 500px; } table th:nth-of-type(2) { } 命令 含义 mvn help:effect ...

  8. commonJS、AMD、es模块化 区别(表格比较)

    commonJS.AMD.es6模块化 区别(表格比较): table th:first-of-type { } table th:nth-of-type(3) { width: 150px; } t ...

  9. mysql 存储过程知识点

    一.创建存储过程 create procedure sp_name() begin ......... end 二.调用存储过程 1.基本语法:call sp_name(): 注意:存储过程名称后面必 ...

  10. 关于 BigDecimal 的小数位的入舍去操作

    BigDecimal  保留小数 的 入舍操作, 6 中 策略 : RoundingMode 里面的 枚举 和      BigDecimal  的  常量 是等价的  UP(BigDecimal.R ...