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

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

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

Execute sp_recompile P_Sys_OrderRead

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

Execute sp_recompile Order

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

posted @ 2005-12-26 16:27  TerryLee  阅读(1942)  评论(0编辑  收藏  举报