mongodb 内嵌文档 增删改查

可以先看下基本操作

Mongodb c# 基础操作_m0_67918035的博客-CSDN博客Mongodb c# 基础操作 https://blog.csdn.net/m0_67918035/article/details/129304498

1.添加 

[HttpPost("embeddedDocument/add")]
        public async Task embeddedDocumentAdd()
        {
            var emDocument1 = new EmbeddedDocument
            {
                Key = "key1",
                Value = "value1",
                EmbeddedEnumType = EmbeddedEnum.A,

            };
            emDocument1.Id = Yitter.IdGenerator.YitIdHelper.NextId();
            var filter = Builders<Test>.Filter.Eq(a => a.Id, 200453425136140359);
            var filter1 = Builders<Test>.Filter.Eq(a => a.Id, 200453425136140358);
            var filter2 = Builders<Test>.Filter.Eq(a => a.Id, 200453425136140357);
            var update = Builders<Test>.Update.AddToSet(x => x.embeddedDocuments, emDocument1);
            await _testMongoRepository.UpdateAsync(filter, update);
            await _testMongoRepository.UpdateAsync(filter1, update);
            await _testMongoRepository.UpdateAsync(filter2, update);
        }

结果.第一行,第二行都会添加成功,第三行会报错,,所以没有添加上去.

 

2.修改

原数据

 

 /// <summary>
        /// 修改
        /// </summary>
        /// <param name="input"></param>
        /// <returns></returns>
        [HttpPost("embeddedDocument/update")]
        public async Task Update()
        {
            var input = new EmbeddedDocument
            {   Id = 201347133553508422,
                Key = "key1",
                Value = "value2",
                EmbeddedEnumType = EmbeddedEnum.B,

            };
            var filter = Builders<Test>.Filter.Eq(a => a.Id, 200453425136140359) 
                & Builders<Test>.Filter.ElemMatch(x => x.embeddedDocuments, y => y.Id ==input.Id );
            var update = Builders<Test>.Update.Set("embeddedDocuments.$", input);
            await _testMongoRepository.UpdateAsync(filter, update);
        }

修改结果 

3.删除

 

/// <summary>
        /// 删除
        /// </summary>
        /// <param name="input"></param>
        /// <returns></returns>
        [HttpPost("embeddedDocument/delete")]
        public async Task embeddedDocumentDelete()
        {
            var filter = Builders<Test>.Filter.Eq(a => a.Id, 200453126405226565);
            var update = Builders<Test>.Update.PullFilter(x => x.embeddedDocuments, y => y.Id == 200453126405226567);
            await _testMongoRepository.UpdateAsync(filter, update);
        }

结果

 

 4.查

先放下

二.内嵌文档的内嵌文档操作

数据准备

实体类修改了,

 public class Test : BaseEntity
    {
        [BsonRepresentation(BsonType.Double)]
        public decimal Num { get; set; }

        public DateTime? TestTime { get; set; } = DateTime.Now;

        public List<EmbeddedDocument> embeddedDocuments { get; set; }

        public string Name { get; set; }

        public List<EmDocument2> EmDocument2s { get; set; }


    }
    public class EmDocument2 : BaseEntity
    {
        public string StudentName { get; set; }

        [BsonRepresentation(BsonType.Double)]
        public decimal Price { get; set; }

        public PriceEnum priceEnum { get; set; }

        public List<EmbeddedDocument> embeddedDocumentList { get; set; }

    }

    public enum PriceEnum
    {
        [Description("英语")]
        English = 1,
        [Description("数学")]
        Math,
        [Description("语文")]
        Chinese,
    }

1.增

原数据

[HttpPost("/EmDocument2s/embeddedDocumentList/Add")]
        public async Task embeddedDocumentListAdd()
        {
            var input = new EmbeddedDocument();
            input.Id = Yitter.IdGenerator.YitIdHelper.NextId();
            input.EmbeddedEnumType = EmbeddedEnum.B;
            input.Value = "value3";
            input.Key = "key3";

            var filter = Builders<Test>.Filter.Eq(a => a.Id, 201356076902252613) 
                & Builders<Test>.Filter.ElemMatch(x => x.EmDocument2s, y => y.Id == 201356076904349768);
            var update = Builders<Test>.Update.Push("EmDocument2s.$.embeddedDocumentList", input);
            
            await _testMongoRepository.UpdateAsync(filter, update);
        }

结果

 

 2.修改

原数据

[HttpPost("/EmDocument2s/embeddedDocumentList/update")]
        public async Task embeddedDocumentListUpdate()
        {
            var input = new EmbeddedDocument();
            input.EmbeddedEnumType = EmbeddedEnum.A;
            input.Value = "value4";
            input.Key = "key4";

            var filter = Builders<Test>.Filter.Eq(a => a.Id, 201356076902252613);
            var update = Builders<Test>.Update.Set("EmDocument2s.$[g].embeddedDocumentList.$[gg]", input);

            var arrayFilters = new List<ArrayFilterDefinition>
            {
                new BsonDocumentArrayFilterDefinition<BsonDocument>(new BsonDocument("g._id", 201356076904349768)),
                new BsonDocumentArrayFilterDefinition<BsonDocument>(new BsonDocument("gg._id", 201358008255512646)),
            };
            var options = new UpdateOptions { ArrayFilters = arrayFilters };

            await _testMongoRepository.Entities.UpdateOneAsync(filter, update, options);

        }

 结果

 

3.删除 

 

[HttpPost("/EmDocument2s/embeddedDocumentList/delete")]
        public async Task embeddedDocumentListDelete()
        {
            var filter = Builders<Test>.Filter.Eq(a => a.Id, 201356076902252613);
            var update = Builders<Test>.Update.PullFilter("EmDocument2s.$[g].embeddedDocumentList", Builders<BsonDocument>.Filter.Eq("_id", 201359705711312965));

            var arrayFilters = new List<ArrayFilterDefinition>
            {
                new BsonDocumentArrayFilterDefinition<BsonDocument>(new BsonDocument("g._id", 201356076904349768)),
            };
            var options = new UpdateOptions { ArrayFilters = arrayFilters };
            await _testMongoRepository.Entities.UpdateOneAsync(filter, update, options);
        }

4.查询

先放下. 

三.第四层 ,还是有点区别的相对于第三层 ,再深的的话也跟这层一样的套路了,我就不创建实体类了,

1.增 

 public async Task Add()
        {
            var filter = Builders<Test>.Filter.Eq(ab => ab.Id, 第一层id)
                & Builders<Test>.Filter.ElemMatch(x => x.EmDocument2s, y => y.Id == 第二层id);
            var update = Builders<Test>.Update.Push("EmDocument2s.$.embeddedDocumentList.$[g].第四层的list", input);

            var arrayFilters = new List<ArrayFilterDefinition>
            {
                new BsonDocumentArrayFilterDefinition<BsonDocument>(new BsonDocument("g._id", 第三层id)),
            };
            var options = new UpdateOptions { ArrayFilters = arrayFilters };

            await _testMongoRepository.Entities.UpdateOneAsync(filter, update, options);
        }

2.修改

 public async Task Update()
        {
            var filter = Builders<Test>.Filter.Eq(a => a.Id, 第一层id);
            var update = Builders<Test>.Update.Set("EmDocument2s.$[g].embeddedDocumentList.$[gg].第四层的list.$[ggg]", input);

            var arrayFilters = new List<ArrayFilterDefinition>
            {
                new BsonDocumentArrayFilterDefinition<BsonDocument>(new BsonDocument("g._id", 第二层id)),
                new BsonDocumentArrayFilterDefinition<BsonDocument>(new BsonDocument("gg._id", 第三层id)),
                new BsonDocumentArrayFilterDefinition<BsonDocument>(new BsonDocument("ggg._id", 第四层id)),
            };
            var options = new UpdateOptions { ArrayFilters = arrayFilters };

            await _testMongoRepository.Entities.UpdateOneAsync(filter, update, options);

        }

3.删

 public async Task Delete()
        {
            var filter = Builders<Test>.Filter.Eq(a => a.Id, 第一层id);
            var update = Builders<Test>.Update.PullFilter("EmDocument2s.$[g].embeddedDocumentList.$[gg].第四层的list", Builders<BsonDocument>.Filter.Eq("_id", 第四层id));

            var arrayFilters = new List<ArrayFilterDefinition>
            {
                new BsonDocumentArrayFilterDefinition<BsonDocument>(new BsonDocument("g._id", 第二层id)),
                new BsonDocumentArrayFilterDefinition<BsonDocument>(new BsonDocument("gg._id", 第三层id)),
            };
            var options = new UpdateOptions { ArrayFilters = arrayFilters };
            await _testMongoRepository.Entities.UpdateOneAsync(filter, update, options);
        }

全部的代码,我就放进文件上传了.

https://download.csdn.net/download/m0_67918035/87542295icon-default.png?t=N176https://download.csdn.net/download/m0_67918035/87542295

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值