版权声明:个人速查笔记 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;
}