2011-05-11 61 views
2

我目前正在使用它通过它的主键值来获取对象。LINQ-to-SQL通用GetByIDs方法

我想找到一种方法来创建一个类似的方法GetByIDs我可以通过一个IEnumerable(的对象)和ids.contains(pk),但没有包含表达式。

任何人都知道我会怎么做?

Public Function GetByID(Of T As Class)(ByVal pk As Object) As T 
    Dim itemParam = Expression.Parameter(GetType(T), "item") 
    Return GetTable(Of T).Single(
     Expression.Lambda(Of Func(Of T, Boolean))(
      Expression.Equal(
       Expression.Property(itemParam, GetPrimaryKeyName(Of T)), 
       Expression.Constant(pk) 
       ), 
      New ParameterExpression() {itemParam} 
      ) 
     ) 
End Function 

Public Function GetPrimaryKeyName(Of T)() As String 
    Return Mapping.GetTable(GetType(T)).RowType.IdentityMembers(0).Name 
End Function 

回答

1

您需要使用Expression.Call

更新 - 不同过载

Expression.Call(typeof(Enumerable), 
       "Contains", 
       new Type[] { Expression.Constant(...).Type } 
       Expression.Property(...), 
       Expression.Constant(...)); 
+0

我不明白的“新类型[] {Expression.Constant(...)类型的目的。 }“或者应该进入”...“ – 2011-05-11 21:36:23

+0

这是你正在搜索的常量的类型。我假设pk将是一个int – Aducci 2011-05-11 23:51:12

+0

这工作。谢谢! :) – 2011-05-12 00:46:03