我有以下数据层设置:
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
}
这会导致异常:
表达式Where(源: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 中遇到了同样的问题,它只是没有抛出,因为它在客户端上对其进行了评估。
当年话下
UYOU
慕妹3146593