-1

我有一张名为 CateringPurchaseOrder 的桌子。该表包含一个名为“PONO”的列。该列不止一次包含相同的值。我想根据“pono”列中的唯一值检索记录。

例子:

pono  column1
1        value1 
1        value2  
2        value3  
2        value4  

输出:

pono    coulm1 
1           value1  
2           value3  

我尝试过使用以下代码:

IEnumerable<CateringPurchaseOrder> order =   entites.CateringPurchaseOrders.Distinct<CateringPurchaseOrder>(new CateringPorderComparer());

public class CateringPorderComparer : IEqualityComparer<CateringPurchaseOrder>
{
    bool IEqualityComparer<CateringPurchaseOrder>.Equals(CateringPurchaseOrder p1, CateringPurchaseOrder p2)
    {
        return p1.P_O_No == p2.P_O_No;
    }

    int IEqualityComparer<CateringPurchaseOrder>.GetHashCode(CateringPurchaseOrder obj)
    {
        return obj.P_O_No.GetHashCode();
    }
}

我收到以下错误:

LINQ to Entities does not recognize the method 'System.Linq.IQueryable`1[MilitarymessModel.CateringPurchaseOrder] Distinct[CateringPurchaseOrder](System.Linq.IQueryable`1[MilitarymessModel.CateringPurchaseOrder], System.Collections.Generic.IEqualityComparer`1[MilitarymessModel.CateringPurchaseOrder])' method, and this method cannot be translated into a store expression.

你有解决这个问题的方法吗?

4

1 回答 1

4

Linq to entity 无法将您的 CateringPorderComparer 解析为 SQL。

如果这不是问题,您可以在 C# 代码中执行 Distinct 操作,而不是让数据库执行此操作。根据有多少行和有多少重复项,这对您来说可能不是问题。

要在数据库查询之后执行 Distinct,请在执行 distinct 之前将其转换为 Eumerable:

entites.CateringPurchaseOrders.AsEnumerable().Distinct<CateringPurchaseOrder>(
new CateringPorderComparer());
于 2012-04-15T08:42:38.393 回答