sql2005数据库远程备份

--打开高级设置
EXEC sp_configure 'show advanced options', 1
RECONFIGURE
--打开xp_cmdshell扩展存储过程
EXEC sp_configure 'xp_cmdshell', 1
RECONFIGURE
declare @strdirname varchar(100)
declare @RemotePathstr varchar(100)
declare @LocalPathstr varchar(100)
declare @DBName varchar(100)
set @strdirname=replace(substring(convert(varchar(20),getdate(),120),1,10),'-','') --获得日期
--启动computer browser
exec master..xp_cmdshell 'net start "computer browser"'
RECONFIGURE
--添加网络驱动器映射
exec master..xp_cmdshell 'net use z: //192.168.0.3/F$/DataBase "123456" /user:192.168.0.3/administrator'
--实施备份

create table #数据库集合
( 数据库名称 varchar(50) null )
insert into #数据库集合(数据库名称) values('database1')
insert into #数据库集合(数据库名称) values('database2')
insert into #数据库集合(数据库名称) values('database3')


declare @DataBaseName varchar(255) --定义变量来保存值
declare mycursor cursor for select 数据库名称 from #数据库集合 --为所获得的数据集指定游标
open mycursor --打开游标
fetch next from mycursor into @DataBaseName --开始抓第一条数据
while(@@fetch_status=0) --如果数据集里一直有数据
begin
set @DBName=@DataBaseName
set @RemotePathstr = 'Z:/DataBak/'+@DBName+@strdirname+'.bak' --备份路径+命名+备份日期
backup database @DBName to disk=@RemotePathstr
--print @RemotePathstr
fetch next from mycursor into @DataBaseName --跳到下一条数据
end
close mycursor --关闭游标
deallocate mycursor --删除游标

drop table #数据库集合
--删除映射
exec master..xp_cmdshell 'net use z: /delete'
--关闭xp_cmdshell扩展存储过程、高级设置
EXEC sp_configure 'xp_cmdshell', 0
RECONFIGURE
EXEC sp_configure 'show advanced options', 0
RECONFIGURE

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值