首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >检查列表是否包含EntityFramework中其他列表中的项目

检查列表是否包含EntityFramework中其他列表中的项目
EN

Stack Overflow用户
提问于 2014-02-08 10:08:10
回答 3查看 112.8K关注 0票数 49

我有一个实体Person,它有一个与之相关联的位置列表。我需要查询Persons表,并从位置列表(条件)中获取至少有一个位置的所有位置。以下方法是可行的,但效率非常低:

代码语言:javascript
复制
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中实现这一点的最好方法是什么?

EN

回答 3

Stack Overflow用户

发布于 2014-02-08 11:52:08

我会建议:

代码语言:javascript
复制
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列表很大,那么你最终会有一个巨大的查询。

票数 91
EN

Stack Overflow用户

发布于 2014-02-08 10:18:51

尝试切换到joins,而不是执行海量数据包括:

代码语言:javascript
复制
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();

显然,修改这一行以匹配您的类和/或连接属性。

代码语言:javascript
复制
join l in Location on p.PersonId equals l.PersonId

我希望这会产生一个更友好的执行计划。

票数 9
EN

Stack Overflow用户

发布于 2021-11-27 08:45:46

你可以试试这个。

代码语言:javascript
复制
List<EnquirePriceSub> e = getSomethings();
var data = appDb.EnquirePriceSubs.Where(w=> e.Select(s=>s.Id).Contains(w.Id)).ToList();
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/21641016

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档