我在数据库中有一个项目列表,我用以下方式检索它:AE_AlignedPartners
List<AE_AlignedPartners> ae_alignedPartners_olds = ctx.AE_AlignedPartners.AsNoTracking().ToList();
比,我得到并序列化了一个使用JSON的新列表(具有相同的对象类型):
List<AE_AlignedPartners> ae_alignedPartners_news = GetJSONPartnersList();
比我得到两者的交集:
var IDSIntersections = (from itemNew in ae_alignedPartners_news
join itemOld in ae_alignedPartners_olds on itemNew.ObjectID equals itemOld.ObjectID
select itemNew).Select(p => p.ObjectID).ToList();
现在,由于这些交集,我需要检查某些记录是否已更改,检查许多字段,然后添加到更新的“监视”列表中。代码如下:
IList<AE_AlignedPartners> ae_alignedPartners_toUpdate = new List<AE_AlignedPartners>();
foreach (var item in IDSIntersections)
{
var itemOld = ae_alignedPartners_olds.First(p => p.ObjectID == item);
var itemNew = ae_alignedPartners_news.First(p => p.ObjectID == item);
if (itemOld.Field1 != itemNew.Field1 ||
itemOld.Field2 != itemNew.Field2 ||
itemOld.Field3 != itemNew.Field3 ||
itemOld.Field4 != itemNew.Field4 ||
itemOld.Field5 != itemNew.Field5 ||
itemOld.Field6 != itemNew.Field6 ||
itemOld.Field7 != itemNew.Field7 ||
itemOld.Field8 != itemNew.Field8 ||
itemOld.Field9 != itemNew.Field9)
{
AE_AlignedPartners toUpdate = mapper.Map<AE_AlignedPartners, AE_AlignedPartners>(itemNew);
toUpdate.ID = itemOld.ID;
ae_alignedPartners_toUpdate.Add(toUpdate);
}
}
这是非常慢的(发布约4分钟,约70k条记录)。
最近我在这里发现了,它确实加快了比较的进程。IEqualityComparer
在这种情况下,我可以利用它吗?或者哪些是有效的优化?
我不会使用建议的,因为这将意味着现在需要大量的重构(我将在下一个项目中这样做,承诺)。FullOuterJoin
有什么提示吗?谢谢
千万里不及你
慕哥9229398
相关分类