我有一个实体Person,它有一个与之相关联的位置列表。我需要查询Persons表,并从位置列表(条件)中获取至少有一个位置的所有位置。以下方法是可行的,但效率非常低:
var searchIds = new List<int>{1,2,3,4,5};
var result = persons.Where(p => p.Locations.Any(l => searchIds.Any(id => l.Id == id)));这对于较小的列表(例如5-10个searchIds和一个有5-10个位置的人)很有效。问题是有些人可能有100个位置,而搜索也可以一次搜索100个位置。当我尝试执行上面的EF时,它实际上生成了一个SQL语句,但由于嵌套太深而失败。虽然嵌套本身已经是一个问题,但即使它可以工作,我仍然不太可能使用2000+ SQL语句。
注意:真正的代码还包括多个级别和父子关系,但我确实设法将其简化为仅使用id的结构,而不是完整的对象。
在EF中实现这一点的最好方法是什么?
发布于 2014-02-08 11:52:08
我会建议:
var searchIds = new List<int>{1,2,3,4,5};
var result = persons.Where(p => p.Locations.Any(l => searchIds.Contains(l.Id)));Contains将被转换为IN语句。
请记住,id列表包含在sql语句中。如果你的id列表很大,那么你最终会有一个巨大的查询。
发布于 2014-02-08 10:18:51
尝试切换到joins,而不是执行海量数据包括:
var searchIds = new List<int>{1,2,3,4,5};
var results = (from p in persons
join l in Location on p.PersonId equals l.PersonId
where searchIds.Contains(l.Id)
select p).Distinct().ToList();显然,修改这一行以匹配您的类和/或连接属性。
join l in Location on p.PersonId equals l.PersonId我希望这会产生一个更友好的执行计划。
发布于 2021-11-27 08:45:46
你可以试试这个。
List<EnquirePriceSub> e = getSomethings();
var data = appDb.EnquirePriceSubs.Where(w=> e.Select(s=>s.Id).Contains(w.Id)).ToList();https://stackoverflow.com/questions/21641016
复制相似问题