我有两个 IEnumerable 集合,我想合并它们。
选择与特定类别关联的新闻对象。当用户按类别过滤时,我还希望显示已标记为另一个类别的新闻文章。
因此,我有另一个查询返回标记有特定子类别的新闻对象。
现在我想合并这两个集合,删除重复项(作为与主要类别关联的新闻文章,也可能被标记为第二个类别)。
var catNews = model.Category.News.SelectMany(n => n.News); //get news article associated to the category
var tagNews = _nr.GetNews(model.Category.relatedCategoryName); //this selects news by tags - which I want as the related category name
model.News = catNews.Union(tagNews).OrderByDescending(p => p.Date); //union the two collections
但是,model.News 现在包含两篇相同的新闻文章,我不确定为什么 union 应该使用默认的相等比较器?
我是不是做错了什么?我正在使用 EF Code First,我的主键是新闻 ID。
我解决这个问题的方法是将 catNews id 列表传递给 GetNews 函数并排除它们
if (excludeIds != null)
q = q.Where(n => !excludeIds.Contains(n.ID));
但是当我认为 union 会删除相同的文章时,我不确定为什么我必须这样做?
最佳答案
我猜你不是从 Entity Framework 上下文的同一个实例加载这两个集合。默认相等比较器将比较引用,如果您使用相同的上下文,当 Id
匹配时,它确实会在两个集合中返回相同的 News
实例,但如果您使用不同的上下文,每个集合将包含自己的 News
实例,Union
将与 Concat
执行相同的操作。在这种情况下,您必须覆盖 News
实体中的 Equals
(和 GetHaschCode
)以比较 Id
或使用自定义比较器.
关于c# - EF Code First - Linq to Entities Union EqualityComparer,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6068575/