У меня есть следующие настройки уровня данных:
public class Repository : IRepository {
private readonly MyDbContext _dbContext;
public List<Meter> Search(Expression<Func<Meter,bool>> criteria)
IQueryable<Meter> results = _dbContext.Meters;
return results.Where(criteria).ToList();
}
}
}
... from a client class:
IRepository _repository;
public void ClientMethod () {
ICollection<int> ids = new List<int>() {1, 2, 3);
var results = _repository.Search(c=> ids.Contains(c.Id)); // This throws exception
}
Это приводит к исключению:
выражение Где (источник: DbSet, предикат: (m) => (Необработанный параметр: __ids_0) .Contains (m.Id)) 'не может быть переведен. Либо переписать запрос в форме, которую можно перевести, либо явно переключиться на оценку клиента, вставив вызов либо AsEnumerable (), AsAsyncEnumerable (), ToList (), либо ToListAsync ()
Ноесли я изменю ссылку на коллекцию на IEnumerable или List, она будет работать:
public void ClientMethod () {
// This works
List<int> ids = new List<int>() {1, 2, 3);
var results = _repository.Search(c=> ids.Contains(c.Id));
// This works
IEnumerable<int> ids = new List<int>() {1, 2, 3);
var results = _repository.Search(c=> ids.Contains(c.Id));
}
Почему она не работает для ICollection, а работает для IEnumerable и List? Многие из моих клиентских методов принимают ICollection в качестве параметра.
Я использую EF Core 3.0, но я считаю, что у меня была та же проблема в 2.1, она просто не вылетала, поскольку вместо этого оценивала ее на клиенте.