zoukankan      html  css  js  c++  java
  • Mongodb 批量Upsert

            List<UpdateOneModel<Entity>> requests = new List<UpdateOneModel<Entity>>(entities.Count());
            foreach (var entity in entities)
            {
                var filter = new FilterDefinitionBuilder<Entity>().Where(m => m.Field1 == entity.Field1 && m.Field2== entity.Field2);
                var update = new UpdateDefinitionBuilder<Entity>().Set(m => m.Field1, entity.Field1).Set(m => m.Field2, entity.Field2);
                var request = new UpdateOneModel<Entity>(filter, update);
                request.IsUpsert = true;
                requests.Add(request);
            }
            await Collection.BulkWriteAsync(requests);
     
    

      http://stackoverflow.com/questions/34543056/mongodb-c-sharp-driver-upsert-many-based-on-candidate-key

    我的:

    var advisorEmails = Database.GetCollection<AdvisorEmail>(Settings.AdvisorEmailCollection).Find(Builders<AdvisorEmail>.Filter.In(x => x.Id, dicAdvisorEmail.Keys)).ToList();
    					if (advisorEmails != null && advisorEmails.Count > 0) {
    						List<UpdateOneModel<AdvisorEmail>> lstUpdateActions = new List<UpdateOneModel<AdvisorEmail>>();
    						List<string> lstRemoveAdvisorEmailIds = new List<string>();
    						foreach (AdvisorEmail advisorEmail in advisorEmails)
    						{
    							if (dicAdvisorEmail.ContainsKey(advisorEmail.Id)) {
    								List<string> lstRemoveIds = dicAdvisorEmail[advisorEmail.Id];
    								List<string> lstnewIds = new List<string>();
    								foreach (string s in advisorEmail.ClientIds) {
    									if (!lstRemoveIds.Contains(s)) lstnewIds.Add(s);
    								}
    								if (lstnewIds.Count > 0)
    								{
    									var filter = new FilterDefinitionBuilder<AdvisorEmail>().Where(m => m.Id == advisorEmail.Id);
    									var update = new UpdateDefinitionBuilder<AdvisorEmail>().Set(m => m.ClientIds, lstnewIds);
    									var action = new UpdateOneModel<AdvisorEmail>(filter, update);
    									action.IsUpsert = true;
    									lstUpdateActions.Add(action);
    
    								}
    								else {
    									lstRemoveAdvisorEmailIds.Add(advisorEmail.Id);
    								}
    							}
    						}
    						if (lstUpdateActions.Count > 0)
    							Database.GetCollection<AdvisorEmail>(Settings.AdvisorEmailCollection).BulkWrite(lstUpdateActions);
    						if (lstRemoveAdvisorEmailIds.Count > 0)
    							LocalAdvisorEmailDB.DeleteMany(Filter<AdvisorEmail>().In(x => x.Id, lstRemoveAdvisorEmailIds));
    					}
    

      

  • 相关阅读:
    datagridview 数据刷新 从新绑定
    SVN 出现This client is too old to work with working copy...错误
    【转】ASPX和HTML获取系统根目录的路径
    C#程序最小化到托盘图标
    Winform的html编辑控件htmleditor 有时候无法为里面HTML属性初始化
    C# HttpWebRequest保存cookies模拟登录的方法【z】【解决】
    快速生成解决方案 ctrl + shilf + b
    datagridview只允许单选
    数据库int类型 才可以自增长
    C# dataTable实用例
  • 原文地址:https://www.cnblogs.com/Cavalry/p/6603470.html
Copyright © 2011-2022 走看看