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


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

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
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值