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