.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缓慢的原因,如果有一个解决方案. – – 补充评论: 性能命中绝对是因为使用排序函数(row_number)的2列,但是我无法避免它们需要它们. 解决方法我要在这里出去,假设你有很多行ID = 1.如果没有,请更正我. SQL Server正在处理您的查询缓慢的一个可能的原因是它查看查询并执行:
如果列或列集合具有较低的选择性(即,唯一值的数量远远小于行数),则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 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |