gpt4 book ai didi

linq - 带有 LINQ 的 Entity Framework 在 WHERE 子句中使用 CONTAINS 对于大整数列表非常慢

转载 作者:行者123 更新时间:2023-12-01 15:50:05 25 4
gpt4 key购买 nike

我有一个函数,它首先查询数据库中的一个函数,该函数返回允许用户查看的员工列表。这会在几毫秒内运行。使用此列表,我查询员工表以获取允许该用户查看的所有员工。当我在查询分析器中运行生成的 sql 时,它只需要几毫秒。当它从 Entity Framework 运行时,它需要超过 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 需要这么长时间?

最佳答案

返回一个 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;

关于linq - 带有 LINQ 的 Entity Framework 在 WHERE 子句中使用 CONTAINS 对于大整数列表非常慢,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18195814/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com