entity framework iqueryable.count()很慢 什么原因,请给解答一下,谢谢
exec sp_executesql N'SELECT
[GroupBy1].[A1] AS [C1]
FROM ( SELECT
COUNT(1) AS [A1]
FROM [dbo].[tWorkLog] AS [Extent1]
LEFT OUTER JOIN [dbo].[tWorkLogDetail] AS [Extent2] ON [Extent1].[sGuid] = [Extent2].[sGuidtWorkLog]
WHERE ([Extent1].[dCreateDate] >= @p__linq__0) AND ([Extent1].[dCreateDate] < @p__linq__1) AND ([Extent1].[sNametBaseEmployee] = @p__linq__2)
) AS [GroupBy1]',N'@p__linq__0 datetime2(7),@p__linq__1 datetime2(7),@p__linq__2 varchar(8000)',@p__linq__0='2010-08-26 00:00:00',@p__linq__1='2012-09-27 00:00:00',@p__linq__2='裴建'
这是sql 但是在sql server中运行并不慢 是什么原因
count无罪,关键是你上面的结果集zl的查询慢
获取 生成count的sql语句,再分析一下慢的原因
用SQL Profiler看一下最终执行的SQL语句是什么?
sql跟踪一下
Sql跟踪一下,你上在写的那个查询好像太复杂了点。所以导致count的时候慢。用SQL Profiler看一下最终执行的SQL语句是什么?贴出来让我们分析分析。
exec sp_executesql N'SELECT
[GroupBy1].[A1] AS [C1]
FROM ( SELECT
COUNT(1) AS [A1]
FROM [dbo].[tWorkLog] AS [Extent1]
LEFT OUTER JOIN [dbo].[tWorkLogDetail] AS [Extent2] ON [Extent1].[sGuid] = [Extent2].[sGuidtWorkLog]
WHERE ([Extent1].[dCreateDate] >= @p__linq__0) AND ([Extent1].[dCreateDate] < @p__linq__1) AND ([Extent1].[sNametBaseEmployee] = @p__linq__2)
) AS [GroupBy1]',N'@p__linq__0 datetime2(7),@p__linq__1 datetime2(7),@p__linq__2 varchar(8000)',@p__linq__0='2011-09-01 00:00:00',@p__linq__1='2012-10-26 00:00:00',@p__linq__2='裴建'
但是在sql server中运行并不慢 是什么原因
linq to entities的查询是延迟执行的,只有在执行结果集的ToList()、Count()、遍历等取结果的方法中才会执行。在你上面的代码中Count()之前,并未真正的查找数据源,所以速度很快,执行count后,开始查询数据并统计数据行,这个时候如果数据量大的话,会非常慢(你在SQL企业管理器中执行那么大量数据的查询一样会慢)。
所以在ling to entities查询中,底层方法直接返回IQueryable<T>即可,在进行筛选后再取数,就不会慢了