1

我想让这个工作:

DBSet 构造函数:

dbset = DataContext().[Set](Of T)()

调用:(Count & Page 用于分页,例如 Count = 20 和 Page = 1,对于前 20 个值)。排序应该按名称

LeverancierService.GetLeveranciers(Function(el) el.Name, Count, Page)

c# 中的等价物:LeverancierService.GetLeveranciers(el=> el.Name, Count, Page)

给出错误的方法(如上所示的参数):

 Public Overridable Function GetAllPaged(orderby As Expression(Of Func(Of T, IComparable)), ByVal Count As Integer, ByVal Page As Integer) As IEnumerable(Of T)
      Return dbset.OrderBy(orderby).Skip((Page - 1) * Count).Take(Count).ToList()
 End Function

已经尝试将其更改为此,但它给出了相同的错误:

 Public Overridable Function GetAllPaged(Of TOrderBy)(orderby As Expression(Of Func(Of T, TOrderBy)), ByVal Count As Integer, ByVal Page As Integer) As IEnumerable(Of T)
        Return dbset.OrderBy(orderby).Skip((Page - 1) * Count).Take(Count).ToList()
 End Function

错误:

 Unable to cast the type 'System.String' to type 'System.IComparable'. LINQ to Entities only supports casting Entity Data Model primitive types.

知道怎么做吗?

额外信息:

我在一个 DDD 分层的应用程序中,所以参数应该保持不变,因为被调用的方法是一个被覆盖的接口(例如,如果我改变这个,我必须这样做 200 次左右,因为它在 VB.Net而不是在 C# 中(= 1 更改))

4

1 回答 1

1

这是我的样本。我希望它能解决你的问题:

如果您的dbset 类型未定义

Public Function Test(Of TEntity As Class, TKey) _
    (keySelector As Expression(Of Func(Of TEntity, TKey))) As IList(Of TEntity)
    Return DataContext.Set(Of TEntity).OrderBy(keySelector).ToList
End Function

用法:

Repository.Test(Function(obj As MyEntity) obj.Name)

如果您的dbset 类型已定义,您可以使用此其他示例:

    Public Function Test2(Of TKey) _
        (keySelector As Expression(Of Func(Of MyEntity, TKey))) _
        As IList(Of MyEntity)
        Return DataContext.Set(Of MyEntity).OrderBy(keySelector).ToList
    End Function

像这样使用:

Repository.Test(Function(obj) obj.Name)
于 2012-04-04T17:27:39.160 回答