面向云技术架构 - 痴者工良

  • 首页
  • 工良写的电子书
    • kubernetes 教程
    • 从 C# 入门 Kafka
    • 多线程和异步
    • 动态编程-反射、特性、AOP
    • 表达式树
  • 本站文章导航
  • 隐私政策
愿有人陪你颠沛流离
遇到能让你付出的事物或者人,都是一种运气。
能遇到,就该珍惜。或许你们最终没能在一起,但你会切实地感受到力量。
正因为这样,那段相遇才变得有价值,才没有辜负这世间的每一段相遇。
  1. 首页
  2. .NET
  3. 正文

C# Mongodb 操作:嵌套、数组 等示例

2022年12月7日 220点热度 0人点赞 0条评论
内容纲要

1,一个字段是数组,如果数组中不存在这个记录时,向数组增加一个记录。

            FilterDefinitionBuilder<WorkflowDo> fd = Builders<WorkflowDo>.Filter;
            var f = fd.And(fd.Eq(x => x.Id, record.Id), fd.Not(fd.ElemMatch(x => x.Definition, x => x.Version == newVersionStr)));

            UpdateDefinitionBuilder<WorkflowDo> up = Builders<WorkflowDo>.Update;
            var p = up.Push(x => x.Definition, definition);
            var result = await collection.UpdateOneAsync(f, p);

首先是区配条件,找到这个根记录、数组中是否已经存在这个记录。

            var f = fd.And(fd.Eq(x => x.Id, record.Id), fd.Not(fd.ElemMatch(x => x.Definition, x => x.Version == newVersionStr)));

然后通过 Push ,向数组推送一个记录。

up.Push(x => x.Definition, definition);

这样,并不需要提前查询数据库一次。

条件更新:

        public async Task<ServiceResult> SetStateAsync(ObjectId id, WorkflowInstanceStatus state)
        {
            var f = Builders<WorkflowInstanceDo>.Filter.Where(x => x.Id == id);
            UpdateDefinitionBuilder<WorkflowInstanceDo> up = Builders<WorkflowInstanceDo>.Update;

            var p = up.Set(x => x.Status, state);
            var collection = _mongodb.GetCollection<WorkflowInstanceDo>();

            var result = await collection.UpdateOneAsync(f, p);
            return R.UpdateSuccess();
        }
本作品采用 知识共享署名-非商业性使用-相同方式共享 4.0 国际许可协议 进行许可
标签: c mongodb 嵌套 数组 示例
最后更新:2022年12月29日

痴者工良

高级程序员劝退师

点赞
< 上一篇
下一篇 >

文章评论

razz evil exclaim smile redface biggrin eek confused idea lol mad twisted rolleyes wink cool arrow neutral cry mrgreen drooling persevering
取消回复

COPYRIGHT © 2022 whuanle.cn. ALL RIGHTS RESERVED.

Theme Kratos Made By Seaton Jiang

粤ICP备18051778号

粤公网安备 44030902003257号