我首先使用实体框架 6 代码,我有一个简单的模型:
public class Task
{
[Key]
public int aid {get;set;}
[MaxLength(256)]
public string Memo {get;set;}
}
然后我得到一个模型:
int id = 3;
from t in db.Tasks
where t.aid == id
select t;
或
int id = 3;
db.Tasks.Find(id);
肯定是快但不是......
我在 IntelliTrace 中查看由 EF ORM 生成的 SQL,如下所示:
DECLARE @p__linq__0 AS SQL_VARIANT;
SET @p__linq__0 = 3;
SET STATISTICS TIME ON
SET STATISTICS IO ON
SELECT
[Limit1].[aid] AS [aid],
[Limit1].[Memo] AS [Memo]
FROM ( SELECT TOP (1)
[Extent1].[aid] AS [aid],
[Extent1].[Memo] AS [Memo]
FROM [dbo].[Task] AS [Extent1]
WHERE [Extent1].[aid] = @p__linq__0
) AS [Limit1]
SET STATISTICS TIME OFF
SET STATISTICS IO OFF
我添加了 SET STATISTICS 并在 SSMS 中对其进行了测试。
表“任务”。 扫描计数 1, ...
它使用SQL_VARIANT!执行计划是扫描表而不是聚簇查找!
为什么 EF 这样做?!我能避免吗?
(带有 SQL Server 2012 的 LocalDB)
最佳答案
我发现了一个问题!
这是因为我在 IntelliTrace 中查看了 sql。
IntelliTrace 将隐藏所有变体并将它们显示为SQL_VARIANT。
我通过 SQL Server Profiler 得到了实际的 SQL,sql 是:
exec sp_executesql N'SELECT
[Limit1].[aid] AS [aid],
[Limit1].[Memo] AS [Memo]
FROM ( SELECT TOP (1)
[Extent1].[aid] AS [aid],
[Extent1].[Memo] AS [Memo]
FROM [dbo].[Task] AS [Extent1]
WHERE [Extent1].[aid] = @p__linq__0
) AS [Limit1]',N'@p__linq__0 int',@p__linq__0=3
可以用seeking查询数据。
关于c# - 我可以避免 Entity Framework 使用 SQL_VARIANT 来查询吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25688498/