SQL Server SQL性能优化之参数化性能优化之参数化
数据库参数化的模式
数据库的参数化有两种方式,简单(simple)和强制(forced),默认的参数化默认是“简单”,简单模式下,如果每次发过
来的SQL,除非完全一样,否则重编译它(特殊情况会自动参数化,正是本文想说的重点)
强制模式是将adhoc SQL强制参数化,避免每次运行的时候因为参数值的不同而重编译,这里不详细说明。
这首先要感谢“潇湘隐者”大神的提示,当时也是遇到一个实际问题,发现执行计划对数据行的预估,怎么都不对,有观察
到无论怎么改变参数,SQL语句执行前都没有重编译,疑惑了好一会,这个问题正是简单参数化模式下,对某些SQL自动参数
化造成执行计划重用引起的,也是本文想表达的重点。
这个问题之前写过,当时也只是看书上理论上这么说的,没有想到其带来的影响
该参数是一个数据级别的选项,设置情况可以参考下图
什么情况下会自动参数化
简单参数化模式下,对于有且只有一种执行方式的Adhoc SQL语句,SQL Server会自动参数化它,从而达到重用执行计划
的目的。
究竟哪些类型的SQL会被自动参数化,后面会举例说明。
自动参数化会存在哪些问题
在简单模式下,SQL对于某些SQL会自动参数化他,避免每次都重编译。
SQL Server 自动参数化SQL语句的行为,能够避免一些重编译,原本也是出于“好意”,但是这种“好意”往往不一定总是给
我们带来好处。
举例说明什么情况下会自动参数化
先造一个简单的测试环境
create table TestAuotParameter
(
id int not null,
col2 varchar(50)
)
GO
declare @i int=0
评论0
最新资源