要使用Except、Intersect的IEqualityComparer

本文关键字:Intersect IEqualityComparer Except | 更新日期: 2023-09-27 18:26:50

我正在尝试实现IEqualityComparer,这样我就可以比较自定义对象的相等性和差异性。

场景:我有10批在不同时间导入的记录集。我需要查看最近的记录集,并将其与以前的所有记录集进行比较,看看哪些记录以前出现过,哪些记录是第一次出现。

我的代码看起来很稳定,我不明白为什么这不起作用。似乎所有的记录都被区分为以前存在的,没有任何记录是新的。

顺便说一句,如果我只是选择一个var,我的记录加载速度实际上快了一百万倍。有办法在var类型上设置IEqualityComparer吗?还是取决于特定的对象类型?

这是提取记录的代码:



    List currentRecords = (from importRecord in db.ImportRecords
                join i in db.Imports on importRecord.ImportId equals i.ImportId
                where i.ImportId == importId
                select new RecordLite
                {
                    RecordId = importRecord.RecordId,
                    IdCode = importRecord.IdCode,
                    IdText1 = importRecord.IdText1,
                    IdText2 = importRecord.IdText2,
                    UniqueId = importRecord.UniqueId,
                }).ToList();
            List historicalRecords = (from importRecord in db.ImportRecords
                join i in db.Imports on importRecord.ImportId equals i.ImportId
                where i.CustomerId == customerId
                select new RecordLite
                {
                    RecordId = importRecord.RecordId,
                    IdCode = importRecord.IdCode,
                    IdText1 = importRecord.IdText1,
                    IdText2 = importRecord.IdText2,
                    UniqueId = importRecord.UniqueId,
                }).ToList();
            List newRecords = currentRecords.Except(historicalRecords, new RecordLiteComparer()).ToList();
            List oldRecords = currentRecords.Intersect(historicalRecords, new RecordLiteComparer()).ToList();

这是我的课&IEqualityComparer


    public class RecordLite
    {
        public int RecordId { get; set; }
        public string IdCode { get; set; }
        public string IdText1 { get; set; }
        public string IdText2 { get; set; }
        public string UniqueId { get; set; }
    }
    public class RecordLiteComparer : IEqualityComparer
    {
        public bool Equals(RecordLite x, RecordLite y)
        {
            if (object.ReferenceEquals(x, y))
                return true;
            if (x == null || y == null)
                return false;
            return x.IdCode.Equals(y.IdCode, StringComparison.CurrentCultureIgnoreCase);
        }
        public int GetHashCode(RecordLite obj)
        {
            return new { obj.IdCode }.GetHashCode();
        }
    }

要使用Except、Intersect的IEqualityComparer

好吧,我发现问题不在于代码,而在于我的逻辑。

在选择以前的记录时,我并没有排除当前的记录集。因此,在进行比较时,所有记录都被认为是旧的,因为所有记录都存在于历史记录中,包括我试图对照的记录。

基本上只需要更新到此行

where i.CustomerId == customerId && i.ImportId != importId