2011-05-11 49 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