SQL Server 如何在运行时重编译存储过程

来源:互联网 发布:eclipse优化运行速度 编辑:程序博客网 时间:2024/05/23 16:54

有两种方法动态重编译存储过程:

1.在Create时加上RECOMPILE选项

CREATE PROCEDURE dbo.PersonAge (@MinAge INT, @MaxAge INT) 
WITH RECOMPILE 
AS 
SELECT * 
FROM dbo.tblTable


2.在执行时加上RECOMPILE选项


EXEC dbo.PersonAge 65,70 WITH RECOMPILE

不推荐使用第二种方法,尤其在生产环境或是存储过程特别大的时候。


=========================================================================
实际工作中遇到的问题及解决方案:

使用VC++ 6.0 编写程序程序调用存储过程,实现数据的检索。
在开发过程中,发现原来的存储过程存在性能问题,需要修改,修改之后在查询分析器中调用速度很快,但是在程序中调用没有任何改变,于是新建了一个存储过程,内容是一样的,只是名称不同,修改程序调用这个存储过程,速度有了很大的提升,开始怀疑sql server 2008编译的问题,于是删除原来的存储过程,再新建这个存储过程,运行程序,发现还是没有变化,于是在新建存储过程的时候按照上面方法一种所介绍的添加了“WITH RECOMPILE”,在用程序调用这个存储过程,发现速度快了很多,问题基本解决,但是如果存储过程中一直留有“WITH RECOMPILE”这句话,那么存储过程每次都需要进行重新编译,所以使用企业管理器自带的“存储过程修改”功能修改存储过程,将这句话删除,然后用程序调用存储过程发现速度比原来更快了一点(因为不用每次都重新编译存储过程了),最终问题得到解决。
0 0
原创粉丝点击