使用一个属性而不是整个对象来区分[重复]

Posted

技术标签:

【中文标题】使用一个属性而不是整个对象来区分[重复]【英文标题】:Distinct using one property and not entire object [duplicate] 【发布时间】:2015-02-11 01:39:36 【问题描述】:

我正在使用 C# / Entity Framework 并尝试将 Distinct() 与一个属性一起使用,但我找不到正确的语法。

我有什么:

context
.Orders
.Select(o => o.User)
.Distinct();

最后的查询是对整个 User 对象做一个 distinct:

SELECT 
    [Distinct1].[ID] AS [ID], 
    [Distinct1].[Name] AS [Name], 
    [Distinct1].[Email] AS [Email], 
    (...)

我需要的是仅使用一个属性来区分,例如名称。最终查询类似于:

SELECT 
    [ID], 
    [Distinct1].[Name] AS [Name], 
    [Email], 
    (...)

如果我在Distinct() 之前使用ToList(),我可以在Distinct() 中使用EqualityComparer,但我试图避免它,因为我遇到了性能问题,因为它正在加载高负载信息进入内存而不是在数据库中过滤。

【问题讨论】:

检查 MoreLinq code.google.com/p/morelinq , ( DistinctBy : code.google.com/p/morelinq/wiki/OperatorsOverview ) 【参考方案1】:

尝试使用比较器:

public class UserComparer : IEqualityComparer<User>

    public bool Equals(User x, User y)
    
        return (x.Name == y.Name);
    

    public int GetHashCode(User user)
    
        return user.GetHashCode();
    


context.Orders.Select(o => o.User).Distinct(new UserComparer());

我的猜测是实体框架应该基于 Name 而不是整个对象。

【讨论】:

以上是关于使用一个属性而不是整个对象来区分[重复]的主要内容,如果未能解决你的问题,请参考以下文章

如何在不替换 ES6/Javascript 中的整个属性的情况下深度复制对象 [重复]

使用 Json.Net 作为 MVC 中的默认格式化程序,而不是 API [重复]

Jackson中的JSON属性文件不区分大小写[重复]

如何在最终的 TreeSet 中创建硬编码的不区分大小写的值,以便只有“香蕉”而不是“香蕉”作为另一个值 [重复]

在表单中移动对象[重复]

JS检查深层对象属性是不是存在[重复]