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

原创 2004年11月03日 15:31:00

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

 

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

  • zgqtxwd
  • zgqtxwd
  • 2008年04月26日 23:51
  • 114

通过系统存储过程手动执行SQL Server中的Job

系统存储过程sp_start_job 若想通过SQL脚本手动执行SQL Server agent中的Job(作业任务),则可使用系统存储过程sp_start_job。如下是通过Job名字进行执行: ...
  • wstoneh01
  • wstoneh01
  • 2016年01月27日 09:32
  • 1896

SQLServer 2008生成SQL Server 2000的脚本

2008转到2000的步骤 1. 生成for 2000版本的数据库脚本 2008 的manger studio -- 打开"对象资源管理器"(没有的话按F8), 连接到你的实例 -- 右键...
  • webjie
  • webjie
  • 2011年12月25日 20:53
  • 3719

sqlserver2000下生成表结构脚本和导入导出数据内容

1 表结构生成sql脚本 在指定的表【bjgl_code】(以下均以bjgl_code为例)上点击右键,选择【所有任务】-》【生成sql脚本】,在右下角的【将要写入脚本的对象】中选择bjgl_code...
  • yunxian_19
  • yunxian_19
  • 2016年12月02日 16:46
  • 3157

通过job来定时执行的SQL脚本

定时执行的SQL脚本因为要同步一个表,所以每天要同步一次数据,但是对SQL不是精通的我,为了测试写了一段代码来测试定时功能创建一个存储过程,是用来插数据的,没有输出和输出参数ccreate or re...
  • ivan0702
  • ivan0702
  • 2007年08月02日 16:30
  • 996

sqlsever2008 R2 导出sqlsever2000 脚本

由于SQL2008的普及和推广,很多的研发人员大多数使用的是SQL2008数据库的作为开发平台,但是程序开发出来之后,到客户使用的时候,却发现,客户现有的程序是运行在SQL2000中的,高版本的数据库...
  • qq_16959405
  • qq_16959405
  • 2015年05月18日 13:20
  • 978

学习在Sql Server中如何通过SQL语句创建Job

在程序中有用到 让用户自定义一些定时执行的提醒或工作任务所以可能需要用到SQLServer相关创建的Job因目前不熟作业创建的SQL语句所以就1.通过企业管理器的管理处作业的向导  直接建立一个作...
  • freeliver54
  • freeliver54
  • 2007年08月16日 15:59
  • 1124

SQL Server 创建定时任务JOB

1.    SQL Server 代理  → 作业(右键)→新建作业   2.  3.   4.  如图  步骤2 数据库选择必须对应的数据库                步骤3在此...
  • sinat_16998945
  • sinat_16998945
  • 2016年09月19日 16:29
  • 9255

SQL SERVER 查询作业(Job)基本信息及执行情况的sql

SQL SERVER 查询作业(Job)基本信息及执行情况的sql
  • u010533180
  • u010533180
  • 2017年08月12日 15:26
  • 1297

SQL Server 2000导入SQL Server 2005生成脚本的问题

今天用SQL Server 2005生成了脚本,想导入到SQL Server 2000里面去,运行的时候却发现竟然出现N多的错误!在导出脚本的时候我明明是选择了“为服务器版本编写脚本”为SQL Ser...
  • feng19821209
  • feng19821209
  • 2013年11月26日 15:01
  • 1177
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:使用SQL Server 2000创建临时Job异步执行SQL 脚本
举报原因:
原因补充:

(最多只允许输入30个字)