开启xp_cmdshell命令
EXEC sp_configure 'show advanced options', 1;RECONFIGURE;EXEC sp_configure 'xp_cmdshell', 0;RECONFIGURE;
--存储过程
--实现功能:定时将服务器中SQL SERVER 2000数据库备份到局域网中另一台电脑上
--Full BackUp
--Use Master
alter proc bakup_DataBase
as
Declare @strPsw varchar(50)
Declare @strUsr varchar(50)
Declare @strCmdShell varchar(300)
Declare @strDataBaseName varchar(20)
Declare @FullFileName Varchar(200)
Declare @FileFlag varchar(50)
Declare @ToFileName varchar(200)
Declare @SQLStr varchar(500)
Declare @SQLStr2 varchar(500)
Declare @FlagDel varchar(20)
Set @strDataBaseName='WmsHub'--填写数据库名称(如:Soondy)
Set @FileFlag=@strDataBaseName+'_'+replace(replace(convert(char(20),getdate(),20),':','-'),' ','-') --备份的文件命名规则:日期-时间.bak
Set @FileFlag='\DBNAME\_\DATE\_\TIME\.BAK'
set @FileFlag=replace(replace(replace(@FileFlag,'\DBNAME\',@strDataBaseName)
,'\DATE\',convert(varchar,getdate(),112))
,'\TIME\',replace(convert(varchar,getdate(),108),':',''))
Set @strUsr='Administrator\Administrator' --需填写域名\用户名(目标机器的Windows登陆名)
Set @strPsw='90-=op[]l;''\'--需填写Windows登陆密码(如:Soondy)
Set @strCmdShell= 'net use \\172.28.185.14\C$ ' + @strPsw + ' /user:' +@strUsr --需填写IP(目标机器的IP地址,如:172.28.185.14)
Set @FullFileName='E:\DBBackup\'+@FileFlag--+'.BAK'--需填写本地备份临时文件的目录,因为需要先备份到本地再copy到目标机器(如:保存目录为E:\DBBackup\)
Set @ToFileName='\\172.28.185.14\E$\Test\' --需填写IP(目标机器的IP地址)以及保存的目录(如:\\172.28.185.14\E$\Test\)
Set @FlagDel='True'--填写True表示删除本地的备份临时文件,填写False或其他字符表示保留该文件
Set @SQLStr='copy '+@FullFileName+' '+@ToFileName
Set @SQLStr2='del ' +@FullFileName
BackUp DataBase @strDataBaseName To Disk= @FullFileName with init
exec master..xp_cmdshell @strCmdShell--尝试连接到目标机器
exec Master..xp_cmdshell @SQLStr --拷贝到目标机器上
if (@FlagDel ='True') exec master.. xp_cmdshell @SQLStr2--删除本地的备份临时文件
GO