首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >是否可以让Linq-To-Sql将实际值嵌入到查询中,而不是将它们作为参数传递?

是否可以让Linq-To-Sql将实际值嵌入到查询中,而不是将它们作为参数传递?
EN

Stack Overflow用户
提问于 2014-10-31 22:13:33
回答 1查看 183关注 0票数 4

我有下面这段代码:

代码语言:javascript
复制
IQueryable<SomeType> allItems = ...;
var selectedItems = allItems.Where( item => ( item.State == 1 || item.State == 3 ) );
Console.WriteLine( selectedItems.ToString() );

我得到了以下转储的查询:

代码语言:javascript
复制
SELECT [t0].[ItemId], [t0].[State], <other columns>
FROM [Items] AS [t0]
WHERE [t0].[State] = @p0 OR [t0].[State] = @p1

您可以看到,实际值1和3不会插入到查询中,而是作为参数传递,这通常会导致选择次优的执行计划。

我能以某种方式让Ling-To-Sql发出WHERE [t0].[State] = 1 OR [t0].[State] = 3吗?

EN

回答 1

Stack Overflow用户

发布于 2014-10-31 23:58:16

参数化sql是使用像linq to sql或实体框架这样的orm的主要好处之一,这会阻止sql injection。Sql server还将缓存参数化sql的执行计划,从而提高整体应用程序性能。

This是一篇关于参数化sql的好处的好文章。

票数 -1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/26676739

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档