职业IT人-IT人生活圈

 找回密码
 成为会员
搜索
查看: 1005|回复: 0

生成MSSQL Data备份的存储过程

[复制链接]
cayean 发表于 2007-6-7 13:26 | 显示全部楼层 |阅读模式
SET QUOTED_IDENTIFIER OFF
GO
SET ANSI_NULLS OFF
GO


ALTER  PROCEDURE CPP_BackDataBase@databasename varchar(100)) AS
declare @filename varchar(100),@cmd varchar(255)
select @databasename = rtrim(@databasename)
select @filename = 'c:sqlbackup'+ rtrim(convert(varchar(10),getdate(),20))
set @cmd = 'md '+@filename
exec master.dbo.xp_cmdshell @cmd
select @filename = @filename +''+@databasename + rtrim(convert(varchar(10),getdate(),20))
select @filename = ltrim(rtrim(@filename))
select @cmd ='BACKUP DATABASE['+@databasename+'] TO DISK = N'''+@filename +'.bak'' WITH INIT , NOUNLOAD , NAME = N''' +@filename+'备份'', SKIP , STATS = 10, FORMAT '
exec (@cmd)
if(@databasename <> &#39;master&#39; and @databasename <>&#39;msdb&#39;)
begin
  --backup log with truncate_only
  select @filename = &#39;c:sqlbackup&#39;+@databasename+&#39;log.back&#39;

  select @cmd = &#39; BACKUP LOG [&#39;+@databasename+&#39;] TO DISK = N&#39;&#39;&#39;+@filename+&#39;&#39;&#39; WITH INIT , NOUNLOAD , NAME = N&#39;&#39;&#39;+@filename +&#39;LOG Backup&#39;&#39;, NOSKIP , STATS = 10, NOFORMAT &#39;
  exec (@cmd)
  select @cmd = &#39;backup log [&#39;+@databasename+&#39;] with truncate_only&#39;
  exec (@cmd)
end
GO
SET QUOTED_IDENTIFIER OFF
GO
SET ANSI_NULLS ON
GO
您需要登录后才可以回帖 登录 | 成为会员

本版积分规则

QQ|手机版|小黑屋|网站帮助|职业IT人-IT人生活圈 ( 粤ICP备12053935号-1 )|网站地图
本站文章版权归原发布者及原出处所有。内容为作者个人观点,并不代表本站赞同其观点和对其真实性负责,本站只提供参考并不构成任何投资及应用建议。本站是信息平台,网站上部分文章为转载,并不用于任何商业目的,我们已经尽可能的对作者和来源进行了通告,但是能力有限或疏忽造成漏登,请及时联系我们,我们将根据著作权人的要求立即更正或者删除有关内容。

GMT+8, 2024-5-15 04:33 , Processed in 0.125157 second(s), 20 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

快速回复 返回顶部 返回列表