3

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

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

我正在使用 SQL 2008 和 EF5.0

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>.");
    }

似乎当它编写 sql 以具有 IN 子句时,它需要很长时间。有几千个允许的员工,但为什么生成 sql 需要这么长时间?

4

1 回答 1

0

返回一个IQueryable而不是 HashSet,然后将join它与您的 Employee 一起返回IQueryable

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;
于 2013-08-12T20:17:42.180 回答