注意细节:存储过程的重编译

我们都知道,当存储过程引用的表改变时,SQL Server会重新编译该存储过程。但是当我们增加一个有助于存储过程执行效率的索引时,SQL Server却不会重新编译该存储过程。只有当存储过程高速缓存被冲刷时(SQL Server重新启动),存储过程才会被重新编译。

如果想要强制编译一个存储过程,可以调用系统存储过程:

Execute sp_recompile P_Sys_OrderRead

当一张表涉及到的存储过程很多的时候,可以直接指定表(视图)名来重新编译相关的对象:

Execute sp_recompile Order

这条语句将会重新编译依赖于表(视图)Order的所有触发器和存储过程。

支持TerryLee的创业产品Worktile
Worktile,新一代简单好用、体验极致的团队协同、项目管理工具,让你和你的团队随时随地一起工作。完全免费,现在就去了解一下吧。
https://worktile.com
原文地址:https://www.cnblogs.com/Terrylee/p/304889.html