c# - 我可以避免 Entity Framework 使用 SQL_VARIANT 来查询吗?

标签 c# sql entity-framework

我首先使用实体​​框架 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/

相关文章:

c# - ArcGIS 门户 - 在没有提示的情况下登录代码

c# - 缓存 - IDictionary 与顶级键前缀

sql - 当行与其他表中的多行匹配时连接表

c# - Entity Framework 将项目添加到 ICollection 错误

c# - 在高容量 IIS 网站上运行时 Entity Framework 会失败吗

c# - 图像未使用 Asp.Net 从 MySql 数据库中显示

c# - Task.Delay(0) 不是异步的

sql - 获取相关文章的高级方法(语义)

mysql - 如何获取间隔日期列表

c# - 我可以将 SimpleMembership 类加载到 EntityFramework 中吗?