C#需求填坑之路之初识ConcurrentDictionary

版权声明:个人速查笔记 https://blog.csdn.net/qq_33981438/article/details/82797242

最近有个更改查询自然年积分的需求 然后整了半天 贴出自己的解决方案
Dictionary的话value的值是只读的 不能赋值或者更改
TryUpdate 是个好东西 我没有更改以前的查询结构所以 下面各种筛选会造成性能问题
当然客户要求这样做 我觉得写存储性能也不会很高

 				 //dic1保存父供应商ID,和供应商的积分
                ConcurrentDictionary<int?,int?> dic1 = new ConcurrentDictionary<int?,int?>();
                //dic2 保存自子供应商ID和父供应商ID
                ConcurrentDictionary<int?,int?> dic2 = new ConcurrentDictionary<int?,int?>();  
                DateTime time2 = DateTime.Now;
                DateTime time1 = new DateTime(time2.Year,1,1); 
                foreach (V_FenXiaoUser item in datas.Models)
                {
                    if (item.ParentFenXiaoId != null)
                    {
                        dic2.TryAdd(item.FenXiaoId, item.ParentFenXiaoId);
                    }
                    else
                    {
                        dic1.TryAdd(item.FenXiaoId, BllOrder.Get_FenxiaoPointBy_Id(item.FenXiaoId.ToString(),time1,time2));
                    }
                }
                //累加子供应商积分
                foreach (KeyValuePair<int?, int?> item in dic2)
                {
                     var obj = dic1.Where(e => e.Key == item.Value).SingleOrDefault();
                     if (item.Value == obj.Key)
                     {
                        int? c = obj.Value;
                        dic1.TryUpdate(obj.Key,c+= BllOrder.Get_FenxiaoPointBy_Id(item.Key.ToString(), time1, time2), obj.Value);
                     }
                }
                //更新统计积分 自然年1月1号 至当前时间
                foreach (V_FenXiaoUser item in datas.Models)
                {
                    int? o=  dic1.Where(e => e.Key == item.FenXiaoId).SingleOrDefault().Value;
                    item.Score = o;
                }

猜你喜欢

转载自blog.csdn.net/qq_33981438/article/details/82797242