假设我有一个名为Poll
的表,我想写一个LINQ扩展来列出所有ID属于数组的民意调查。例如:
void Main()
{
long[] ids = new long[]{ 1,2,3,4,5,6,7,8,9 };
ListFail<Poll>(Poll, p => p.ID, ids); //Failed!
ListOK<Poll>(Poll, p => p.ID, ids); //OK!
}
public void ListFail<T>(Table<T> obj, Func<T, long> idProperty, long[] ids) where T : class
{
obj.Where(p => ids.Contains(idProperty(p))).ToList().Dump();
}
public void ListOK<T>(Table<T> obj, Func<T, long> idProperty, long[] ids) where T : class
{
obj.ToList().Where(p => ids.Contains(idProperty(p))).ToList().Dump();
}
我不知道为什么我会在ListFail
Method 'System.Object DynamicInvoke(System.Object[])' has no supported translation to SQL.
当我在ToList()
之前添加Where
时,它在ListOK
上运行良好,但当然我不想获得整个Poll
表。
有什么想法吗?
答案 0 :(得分:2)
将Func<T, long>
更改为Expression<Func<T, long>>
。现在,因此,EF不理解它。