--使用waitfor语句延迟或暂停程序的执行
--waitfor{delay‘time‘|time ‘time‘}
delay是指间隔时间 最长到24小时
time是指定时间执行
waitfor delay ‘00:00:10‘ --延迟10秒
A. 使用 WAITFOR TIME
以下示例在晚上 10:20 (22:20) 执行存储过程 sp_update_job。
USE msdb; EXECUTE sp_add_job @job_name = ‘TestJob‘; BEGIN WAITFOR TIME ‘22:20‘; EXECUTE sp_update_job @job_name = ‘TestJob‘, @new_name = ‘UpdatedJob‘; END; GO
B. 使用 WAITFOR DELAY
以下示例在两小时的延迟后执行存储过程。
BEGIN WAITFOR DELAY ‘02:00‘; EXECUTE sp_helpdb; END; GO
这个延时平时不显山露水啊。但是在订阅同步时,或者数据量太大时,会出现问题。丢数据,或者表锁死啊。问题特别多,多余1条的都要考虑十分分批。多余5000肯定要分批了。