EF Code First - Linq to Entities Union EqualityComparer

时间:2011-05-20 07:04:21

标签: c# linq linq-to-entities union ef-code-first

我有两个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现在包含两篇相同的新闻文章,我不确定为什么联盟应该使用默认的相等比较器?

我在这里做错了吗?我使用EF Code First,我的主键是新闻ID。

我解决这个问题的方法是将catNews id列表传递给GetNews函数并将其排除

if (excludeIds != null)
    q = q.Where(n => !excludeIds.Contains(n.ID));

但是当我认为工会会删除相同的文章时,我不确定为什么要这样做?

1 个答案:

答案 0 :(得分:3)

我猜你没有从实体框架上下文的同一个实例加载这两个集合。默认的相等比较器将比较引用,如果使用相同的上下文,当News匹配时,它确实会在两个集合中返回相同的Id实例,但如果使用不同的上下文,则每个集合将包含其自己的{{1实例和News将与Union完全相同。在这种情况下,您必须覆盖Concat实体中的Equals(和GetHaschCode)以比较News或使用自定义比较器。