使用2000创建临时Job异步执行SQL脚本

<script type="text/javascript"> </script> <script type="text/javascript" src="http://pagead2.googlesyndication.com/pagead/show_ads.js"> </script>
<script type="text/javascript"> </script><script type="text/javascript" src="http://pagead2.googlesyndication.com/pagead/show_ads.js"> </script>

应用场景:
   在庞大的中很多复杂的更新查询非常的耗时。为了避免用户长时间的等待,那些耗时的操作可以采用 异步执行的方法,立刻返回执行信息给用户,同时在数据库后台执行操作,等到执行完毕再更新数据表。
   
开发环境:
SQLSERVER2000

解决方案:
   在 SQLSERVER2000中创建一个临时的 Job,(或者固定的 Job,根据具体的应用场景),传递需要执行的 SQLbatch 脚本,然后启动这个 Job。这样就可以在数据库获得异步调用的功能了。由于创建的是临时的 Job
SQLSERVER在该 Job运行结束以后会自动删除该 Job

缺点:该存储过程必须指定数据库的名字

====================================================================================
/******************************************************************************
 *Author:iret
 *Desc: Createtemporary Jobtoprovide asynchronouslyinvoking SQLbatch
 *           在 SQLSERVER2000中创建用于执行异步调用的临时 Job
 * @EXEC SQL: Transact- SQL batch
 * Eample:EXECdbo.AsynchronousInvoking@EXEC SQL= 'UPDTAEcustomer SETbalance=0'
 *缺点:该存储过程必须指定数据库的名字
 *ModifiedDate:2004/11/03
 ******************************************************************************/
CREATEProceduredbo.AsynchronousInvoking
 @EXEC SQLnvarchar(4000)
AS

BEGINTRANSACTION           
 DECLARE@ JobIDBINARY(16) 
 DECLARE@ReturnCodeINT   
 SELECT@ReturnCode=0    

BEGIN

 --Addthe Job
 EXECUTE@ReturnCode=msdb.dbo.sp_add_ Job@ Job_id=@ JobIDOUTPUT,
    @ Job_name=N'temp_ SQL Job',
    @owner_login_name=N'',
    @description=N'descriptionfor Job',--thedescriptionof the Job 
     @category_name=N'[Uncategorized(Local)]',
    @enabled=1,
    @notify_level_email=0,
    @notify_level_page=0,
    @notify_level_netsend=0,
    @notify_level_eventlog=0,
    @delete_level=3
    
 IF(@@ERROR<>0OR@ReturnCode<>0)GOTOQuitWithRollback

 --Addthe Jobsteps
 EXECUTE@ReturnCode=msdb.dbo.sp_add_ Jobstep@ Job_id=@ JobID,
    @step_id=1,
    @step_name=N'step1',
    @command=@EXEC SQL,-- SQL batch
    --缺点:该存储过程必须指定数据库的名字
     @database_name=N'your_database_name',--the databasename ofthe Jobtomanipulate
     @server=N'',
    @database_user_name=N'appuser',
    @subsystem=N'T SQL',
    @cmdexec_success_code=0,
    @flags=0, 1
<script type="text/javascript"> </script> <script type="text/javascript" src="http://pagead2.googlesyndication.com/pagead/show_ads.js"> </script>
<script type="text/javascript"> </script><script type="text/javascript" src="http://pagead2.googlesyndication.com/pagead/show_ads.js"> </script>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值