首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用LINQ的实体框架在WHERE子句中使用CONTAINS对于大整数列表非常慢

使用LINQ的实体框架在WHERE子句中使用CONTAINS对于大整数列表非常慢
EN

Stack Overflow用户
提问于 2013-08-13 04:10:22
回答 1查看 1.7K关注 0票数 3

我有一个函数,它首先查询数据库中的一个函数,该函数返回允许用户查看的员工列表。这在几毫秒内运行。我使用这个列表查询employee表,以获得该用户有权查看的所有员工。当我在查询分析器中运行生成的sql时,它只需要几毫秒。当它从实体框架运行时,它需要8秒以上的时间。

最初,我有一个allowedEmployees列表,但后来读取了http://mikeinba.blogspot.ca/2009/09/speeding-up-linq-contains-queries-with.html,并尝试使用HashSet,但性能仍然很差。如何获得与sql查询分析器中的性能相似的性能?我做错了什么?

我使用的是SQL 2008和EF5.0

代码语言:javascript
复制
public IQueryable<Employee> FindAllByWithPermissions(int eID, Expression<Func<Employee, bool>> predicate)
    {
        if (predicate != null)
        {
            HashSet<int> allowedEmployees = SecurityRepository.GetPermissableEmployees(eID);
            return DataContext.Set<Employee>().Where(predicate).Where(p => allowedEmployees.Contains(p.EmployeeID)).AsQueryable<Employee>(); ;
        }
        throw new ArgumentNullException("Predicate value must be passed to FindBy<T,TKey>.");
    }

看起来,当它编写包含IN子句的sql时,需要很长时间。有几千名允许的员工,但是为什么为它生成sql需要这么长的时间?

EN

回答 1

Stack Overflow用户

发布于 2013-08-13 04:17:42

返回一个IQueryable,而不是一个HashSet,然后用你的雇员IQueryable join它。

代码语言:javascript
复制
var availableEmployees = SecurityRepository.GetPermissableEmployees(eID);
var allEmployees= DataContext.Set<Employee>();

query = from item in allEmployees.Where(predicate)
        join t in availableEmployees on item.EmployeeID equals t.EmployeeID
        select item;
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/18195814

复制
相关文章

相似问题

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