Передача func в качестве параметра в Linq сущностям и ошибка «Внутренний провайдер данных .NET Framework ошибка 1025»
У нас есть класс с именем Task:
public partial class Task : EntityObject
{
public EntityCollection<TaskUser> TaskUsers { get {...} set{...} }
}
У него есть свойство навигации, называемое TaskUsers, которое содержит пользователей, прикрепленных к этому процессу
public partial class TaskUser : EntityObject
{
public User User { get {...} set { } }
}
Каждый объект TaskUser имеет объект User.
Нам даютIQueryable<Task> tasks
, Мы хотим найти задачи, назначенные пользователю с ID = 1. Когда мы используем
tasks.Where(t => t.TaskUsers.Any(a => a.User.ID == 1))
все отлично работает Когда мы используем
Func<TaskUser, bool> function = a => a.User.ID == 1;
return tasks.Where(t => t.TaskUsers.Any(function));
мы получаем хороший'Internal .NET Framework Data Provider error 1025'
ошибка. Почему? Я хочу построить гораздо более сложные фильтры, используяExpression
класс, но если я не могу пройти простойFunc
это не может быть сделано. Что я должен делать?
РЕДАКТИРОВАТЬ
Может быть
Func<TaskUser, bool> function = a => a.User.ID == 1;
return tasks.Where(t => t.TaskUsers.Any(function));
не работает, но
Expression<Func<TaskUser, bool>> expression = a => a.User.ID == 1;
return tasks.Where(t => t.TaskUsers.AsQueryable().Any(expression));
работает! Это все, что мне было нужно.