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
我不明白的“新类型[] {Expression.Constant(...)类型的目的。 }“或者应该进入”...“ – 2011-05-11 21:36:23
这是你正在搜索的常量的类型。我假设pk将是一个int – Aducci 2011-05-11 23:51:12
这工作。谢谢! :) – 2011-05-12 00:46:03