Your Ad Here
首页 | 编程语言 | 网站建设 | 游戏天堂 | 冲浪宝典 | 网络安全 | 操作系统 | 软件时空 | 硬件指南 | 病毒相关 | IT 认证
软讯网络 > 冲浪宝典 > 网络资源 > 使用SQL Server 2000创建临时Job异步执行SQL脚本
【标  题】:使用SQL Server 2000创建临时Job异步执行SQL脚本
【关键字】:SQL,异步,Server,脚本,20,2000,SQL Server,Serv,200,SQL,Server,2000,Job,SQL
【来  源】:网络

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

Your Ad Here


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

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

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

====================================================================================
/******************************************************************************
 * Author: iret
 * Desc: Create temporary job to provide asynchronously invoking SQL batch
 *           在SQL SERVER 2000中创建用于执行异步调用的临时Job
 * @EXECSQL: Transact-SQL batch
 * Eample: EXEC dbo.AsynchronousInvoking @EXECSQL = 'UPDTAE customer SET balance = 0'
 * 缺点:该存储过程必须指定数据库的名字
 * Modified Date: 2004/11/03
 ******************************************************************************/
CREATE Procedure dbo.AsynchronousInvoking
 @EXECSQL nvarchar(4000)
AS

BEGIN TRANSACTION           
  DECLARE @JobID BINARY(16) 
  DECLARE @ReturnCode INT   
  SELECT @ReturnCode = 0    

BEGIN

  -- Add the job
  EXECUTE @ReturnCode = msdb.dbo.sp_add_job @job_id = @JobID OUTPUT ,
     @job_name = N'temp_sqljob',
     @owner_login_name = N'',
     @description = N'description for job', -- the description of 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 <> 0 OR @ReturnCode <> 0) GOTO QuitWithRollback

  -- Add the job steps
  EXECUTE @ReturnCode = msdb.dbo.sp_add_jobstep @job_id = @JobID,
     @step_id = 1,
     @step_name = N'step1',
     @command = @EXECSQL, -- sql batch
     --缺点:该存储过程必须指定数据库的名字
     @database_name = N'your_database_name', --the database name of the job to manipulate
     @server = N'',
     @database_user_name = N'appuser',
     @subsystem = N'TSQL',
     @cmdexec_success_code = 0,
     @flags = 0,
     @retry_attempts = 0, --execute once only
     @retry_interval = 0,
     @output_file_name = N'',
     @on_success_step_id = 0,
     @on_success_action = 1, -- on success abort
     @on_fail_step_id = 0,
     @on_fail_action = 2 -- on fail abort
     
  IF (@@ERROR <> 0 OR @ReturnCode <> 0) GOTO QuitWithRollback 

  --set the star step id of the job
  EXECUTE @ReturnCode = msdb.dbo.sp_update_job @job_id = @JobID,
              @start_step_id = 1

  IF (@@ERROR <> 0 OR @ReturnCode <> 0) GOTO QuitWithRollback
 
  -- Add the Target Servers
  EXECUTE @ReturnCode = msdb.dbo.sp_add_jobserver @job_id = @JobID,
          @server_name = N'(local)'
         
  IF (@@ERROR <> 0 OR @ReturnCode <> 0) GOTO QuitWithRollback 
 
END

COMMIT TRANSACTION         
GOTO   EndSave             

QuitWithRollback:
  IF (@@TRANCOUNT > 0) BEGIN
    ROLLBACK TRANSACTION 
    RETURN 1
  END
EndSave:

--star the job immediately
EXEC @ReturnCode = msdb.dbo.sp_start_job @job_id = @JobID
 
--return to the invoker immediately
RETURN @ReturnCode

GO
SET QUOTED_IDENTIFIER OFF
GO
SET ANSI_NULLS ON
GO

用Sql语句生成Sqlserver数据字典:【上一篇】
通过OLE DB连接MSSQL Server时出现乱码的解决方法:【下一篇】
【相关文章】
  • 用Sql语句生成Sqlserver数据字典
  • sqlserver中,sql编程的几个小常识
  • 如何获取MSSQLServer,Oracel,Access中的数据字典信息
  • Access数据库与SQLserver2000的数据互导
  • SQL Server中死锁产生的原因及解决办法
  • SQL问题汇编
  • 如何使Microsoft SQL Server的日志文件不会增大
  • 使用SQLDMO从SQL Server中获取信息
  • 使用sqlserver来存放和取得session
  • 使用SQL Server 2000将现有代码作为Web服务提供
  • 【随机文章】
  • 用openssh构建安全网络
  • 太阳定方位之计算 v1.0
  • RFC1723 RIP Version 2
  • 如何编译Linux内核
  • PathFinder-A*寻路算法优化
  • [轉]为服务器控件添加javascript客户端事件
  • 更改“回收站”满的时候的提示信息
  • c++设计新思维第二章读书笔记二:Int2Type的妙用
  • PRODUCT DB2 SYSTEM MONITOR
  • 什么是POP3和SMTP?
  • 【相关评论】
    没有相关评论
    【发表评论】
    姓名:
    邮件:
    随机码*
    评论*
          
    |  首 页  |  版权声明  |  联系我们   |  网站地图  |
    CopyRight © 2004-2007 bbb软讯网络 All Rigths Reserved.