最近有个更改查询自然年积分的需求 然后整了半天 贴出自己的解决方案
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