利用sqlserver作业的功能 将数据库定时备份到某目录下

 

ExpandedBlockStart.gif 代码
--  2011-1-19/15:44 上生成的脚本
--
 由: sa
--
 服务器: 192.168.0.66

BEGIN   TRANSACTION             
  
DECLARE   @JobID   BINARY ( 16 )  
  
DECLARE   @ReturnCode   INT     
  
SELECT   @ReturnCode   =   0      
IF  ( SELECT   COUNT ( * FROM  msdb.dbo.syscategories  WHERE  name  =  N ' [Uncategorized (Local)] ' <   1  
  
EXECUTE  msdb.dbo.sp_add_category  @name   =  N ' [Uncategorized (Local)] '

  
--  删除同名的警报(如果有的话)。
   SELECT   @JobID   =  job_id     
  
FROM    msdb.dbo.sysjobs    
  
WHERE  (name  =  N ' JBPM 备份 ' )       
  
IF  ( @JobID   IS   NOT   NULL )    
  
BEGIN   
  
--  检查此作业是否为多重服务器作业  
   IF  ( EXISTS  ( SELECT    *  
              
FROM     msdb.dbo.sysjobservers 
              
WHERE    (job_id  =   @JobID AND  (server_id  <>   0 ))) 
  
BEGIN  
    
--  已经存在,因而终止脚本 
     RAISERROR  (N ' 无法导入作业“JBPM 备份”,因为已经有相同名称的多重服务器作业。 ' 16 1
    
GOTO  QuitWithRollback  
  
END  
  
ELSE  
    
--  删除[本地]作业 
     EXECUTE  msdb.dbo.sp_delete_job  @job_name   =  N ' JBPM 备份 '  
    
SELECT   @JobID   =   NULL
  
END  

BEGIN  

  
--  添加作业
   EXECUTE   @ReturnCode   =  msdb.dbo.sp_add_job  @job_id   =   @JobID  OUTPUT ,  @job_name   =  N ' JBPM 备份 ' @owner_login_name   =  N ' sa ' @description   =  N ' 没有可用的描述。 ' @category_name   =  N ' [Uncategorized (Local)] ' @enabled   =   1 @notify_level_email   =   0 @notify_level_page   =   0 @notify_level_netsend   =   0 @notify_level_eventlog   =   2 @delete_level =   0
  
IF  ( @@ERROR   <>   0   OR   @ReturnCode   <>   0 GOTO  QuitWithRollback 

  
--  添加作业步骤
   EXECUTE   @ReturnCode   =  msdb.dbo.sp_add_jobstep  @job_id   =   @JobID @step_id   =   1 @step_name   =  N ' 第 1 步 ' @command   =  N ' declare @name varchar(300)
set @name=N
'' E:\ '' + convert(varchar(10),getdate(),112) +  '' .BAK ''  

BACKUP DATABASE [JBPM] TO  DISK = @name WITH  INIT ,  
NOUNLOAD ,  NAME = N
'' JBPM 备份 '' ,  NOSKIP ,  STATS = 10,  NOFORMAT 
' @database_name   =  N ' master ' @server   =  N '' @database_user_name   =  N '' @subsystem   =  N ' TSQL ' @cmdexec_success_code   =   0 @flags   =   0 @retry_attempts   =   0 @retry_interval   =   0 @output_file_name   =  N '' @on_success_step_id   =   0 @on_success_action   =   1 @on_fail_step_id   =   0 @on_fail_action   =   2
  
IF  ( @@ERROR   <>   0   OR   @ReturnCode   <>   0 GOTO  QuitWithRollback 
  
EXECUTE   @ReturnCode   =  msdb.dbo.sp_update_job  @job_id   =   @JobID @start_step_id   =   1  

  
IF  ( @@ERROR   <>   0   OR   @ReturnCode   <>   0 GOTO  QuitWithRollback 

  
--  添加作业调度
   EXECUTE   @ReturnCode   =  msdb.dbo.sp_add_jobschedule  @job_id   =   @JobID @name   =  N ' 第 1 调度 ' @enabled   =   1 @freq_type   =   4 @active_start_date   =   20101127 @active_start_time   =   175000 @freq_interval   =   1 @freq_subday_type   =   1 @freq_subday_interval   =   1 @freq_relative_interval   =   0 @freq_recurrence_factor   =   0 @active_end_date   =   99991231 @active_end_time   =   235959
  
IF  ( @@ERROR   <>   0   OR   @ReturnCode   <>   0 GOTO  QuitWithRollback 

  
--  添加目标服务器
   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 ROLLBACK   TRANSACTION  
EndSave: 


 

 

 

转载于:https://www.cnblogs.com/tzy080112/archive/2011/01/19/1939264.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值