微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

.net – 为什么当参数作为参数传递时,sp_executesql运行速度较慢

查询1 :(闪电快)
sp_executesql "select * from tablesView where Id = 1"

查询2 :(太慢)

sp_executesql "select * from tablesView where Id = @Id",N"@Id int",@Id=1

tablesView – 包含多个连接的视图

LINQ始终将查询转换为Query2表单,因此性能非常差.

问题:我需要query2缓慢的原因,如果有一个解决方案.
和LINQ的一个决议.

– – 补充评论

性能命中绝对是因为使用排序函数(row_number)的2列,但是我无法避免它们需要它们.

解决方法

我要在这里出去,假设你有很多行ID = 1.

如果没有,请更正我.

sql Server正在处理您的查询缓慢的一个可能的原因是它查看查询并执行:

hmm,I wonder what he’s going to pass for that parameter.
is it going to be 1? where I have about a gazillion rows?
or perhaps 1742,where I have just 3
I just don’t kNow,I better do a table scan to be sure to produce an execution plan that will cover all my bases

如果列或列集合具有较低的选择性(即,唯一值的数量远远小于行数),则sql Server有时会还原为tablecan或类似的,以确定性地获取所有行.

至少这是我的经验.特别是当在日期范围内选择具有时间限制数据的表格时,我看到了相同的行为,执行一个WHERE dt< = @dt AND dt> = @dt来获取@dt在一段时间内的所有行在那一行的时间,还原到表扫描,然后当我把实际的日期作为一个文字,它运行得更快.

这里的问题是选择性,sql Server不知道如何在为您的语句构建执行计划时最好地满足所有情况,所以它会尝试猜测.

尝试添加查询提示以指定参数的典型值,即:

sp_executesql "select * from tablesView where Id = @Id option (optimize for (@id = 1742))",@Id=1

原文地址:https://www.jb51.cc/mssql/75577.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐