sqlserver脚本备份固定多个数据库

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了sqlserver脚本备份固定多个数据库相关的知识,希望对你有一定的参考价值。

1.用SqlServer的维护计划



在这里我就不给截图演示了,这个比较简单,无非就是通过sqlserver自己的维护计划拖拽出2个一个‘备份数据库'任务和一个‘清除维护'任务。

需要注意的点:

  1)有备份任务里边选择备份的库尽量选‘所有用户数据库'这项,以免选择了特定数据库备份以后某天添加了新数据库却忘了勾选导致丢备份。

  2)选项验证备份集完整性和压缩备份尽量都选上。

  3)备份的路径尽量别选磁盘根目录。

2.通过脚本+作业的方式备份数据库(非xp_cmdshell)。如果是多个库的话自己写个游标用动态sql的方式即可实现多库备份,我这里就提供个思路偷懒就不整理了。

复制代码 代码如下:

  DECLARE @filename VARCHAR(500)
  DECLARE @date DATETIME
  DECLARE @OLD_DATE DATETIME
  SET @date=GETDATE()
  SET @OLD_DATE=GETDATE()-5 --超过5天的备份即将被删除
  SET @FILENAME = 'E:\存放位置\数据库名称-'+CAST(DATEPART(YYYY,@DATE) AS VARCHAR(10))+'-'+CAST(DATEPART(MM,@DATE) AS VARCHAR(10))+'-'+CAST(DATEPART(DD,@DATE) AS VARCHAR(10))+'.BAK'
  BACKUP DATABASE [数据库名称] TO DISK = @filename WITH COMPRESSION
  EXECUTE master.dbo.xp_delete_file 0,N'E:\存放位置',N'bak',@OLD_DATE,1

  GO

3.通过脚本+作业的方式备份数据库(用xp_cmdshell),如果你觉得你们服务器的网络、代码、以及防火墙足够安全可以开启xp_cmdshell的方式来备份。
  如果数据库没开启xp_cmdshell的功能需要用以下脚本开通此功能,开通以后记得关闭sp_configure。

复制代码 代码如下:

  USE Master
  GO
  EXEC sp_configure 'show advanced options', 1;
  
参考技术A 您可以使用以下步骤来实现备份固定多个数据库的脚本:

新建一个存储过程,例如命名为 "sp_backup_database"。

在存储过程中声明必要的参数,例如备份路径和备份文件名。

使用 "BACKUP DATABASE" 命令备份所有指定的数据库。您可以使用循环来遍历所有需要备份的数据库,然后依次调用 "BACKUP DATABASE" 命令进行备份。

在存储过程结束时,使用 "RETURN" 命令返回备份是否成功的结果。

SQLServer备份脚本

企业管理器
--管理
--SQL Server代理
--右键作业
--新建作业
--"常规"项中输入作业名称
--"步骤"项
--新建
--"步骤名"中输入步骤名
--"类型"中选择"Transact-SQL 脚本(TSQL)"
--"数据库"选择执行命令的数据库
--"命令"中输入要执行的语句:
                      
--确定
--"调度"项
--新建调度
--"名称"中输入调度名称
--"调度类型"中选择你的作业执行安排
--如果选择"反复出现"
--点"更改"来设置你的时间安排为一天一次


然后将SQL Agent服务启动,并设置为自动启动,否则你的作业不会被执行

设置方法:
我的电脑--控制面板--管理工具--服务--右键 SQLSERVERAGENT--属性--启动类型--选择"自动启动"--确定.

 

/*******************完整备份作业*******************/
--完整备份,每周一次
USE Master
GO
declare @str varchar(100)
set @str=‘D:\DBtext\jgj\DBABak\FullBak‘+replace(replace(replace(convert(varchar,getdate(),20),‘-‘,‘‘),‘ ‘,‘‘),‘:‘,‘‘)+‘.bak‘
BACKUP DATABASE [demo] TO [email protected]
WITH RETAINDAYS=15,NOFORMAT,NOINIT,
NAME=N‘Demo完整备份‘,SKIP,NOREWIND,
NOUNLOAD,STATS=10
GO

 


/*******************差异备份作业*******************/
--截断日志
USE Master
GO
BACKUP LOG Demo  WITH NO_LOG
GO
--收缩日志文件
USE Demo
GO
DBCC SHRINKFILE (N‘Demo_log‘,0,TRUNCATEONLY)
GO
--差异备份,每天一次
USE Master
GO
declare @str varchar(100)
set @str=‘D:\DBtext\jgj\DBABak\DiffBak‘+replace(replace(replace(convert(varchar,getdate(),20),‘-‘,‘‘),‘ ‘,‘‘),‘:‘,‘‘)+‘.diff‘
BACKUP DATABASE [Demo] TO [email protected]
WITH DIFFERENTIAL,RETAINDAYS=8,NOFORMAT,NOINIT,
NAME=N‘Demo差异备份‘,SKIP,NOREWIND,
NOUNLOAD,STATS=10
GO

 


/******************日志备份作业*******************/
--日志备份,每小时一次
USE Demo
GO
declare @str varchar(100)
set @str=‘D:\DBtext\jgj\DBABak\logbak‘+replace(replace(replace(convert(varchar,getdate(),20),‘-‘,‘‘),‘ ‘,‘‘),‘:‘,‘‘)+‘.trn‘
BACKUP LOG [Demo] TO [email protected]
WITH RETAINDAYS=3,NOFORMAT,NOINIT,
NAME=N‘Demo日志备份‘,SKIP,NOREWIND,
NOUNLOAD,STATS=10
GO

 


--删除过期的备份文件,每天两次
declare @str varchar(100),@dir varchar(100),@fileName varchar(30)
set @dir=‘del D:\DBtext\jgj\DBABak\‘
set @filename=left(replace(replace(replace(convert(varchar,getdate()-15,20),‘-‘,‘‘),‘ ‘,‘‘),‘:‘,‘‘),8)
set @[email protected]+‘fullbak‘[email protected]+‘*.bak‘
exec xp_cmdshell @str
set @filename=left(replace(replace(replace(convert(varchar,getdate()-8,20),‘-‘,‘‘),‘ ‘,‘‘),‘:‘,‘‘),8)
set @[email protected]+‘diffbak‘[email protected]+‘*.diff‘
exec xp_cmdshell @str
set @filename=left(replace(replace(replace(convert(varchar,getdate()-8,20),‘-‘,‘‘),‘ ‘,‘‘),‘:‘,‘‘),8)
set @[email protected]+‘logbak‘[email protected]+‘*.trn‘
exec xp_cmdshell @str

 

====================================================================== 
SQL还原 
====================================================================== 
1、验证备份 
------------------------------------------------------------ 
restore headeronly from bak3 
restore filelistonly from bak3 with file=1 
restore labelonly from bak3 
restore verifyonly from bak3 
---------------------------------------------------------------------- 
2、从备份中还原 
------------------------------------------------------------------------- 
restore headeronly from bak1 
restore database d1 from bak1 with file=2        --从完全备份中恢复 
---------------------------------------------------------------------- 
restore headeronly from bak2              --从差异备份中恢复 
restore database d2 from bak2 with file=1,norecovery    
restore database d2 from bak2 with file=5,recovery 
---------------------------------------------------------------------- 
restore headeronly from bak3              --从日志备份中恢复 
restore database d3 from bak3 with file=1,norecovery 
restore log    d3 from bak3 with file=2,norecovery 
restore log    d3 from bak3 with file=3,norecovery 
restore log    d3 from bak3 with file=4,norecovery 
restore log    d3 from bak3 with file=5,recovery 
---------------------------------------------------------------------- 
restore database d3 from bak3 with file=1,norecovery      --恢复到指定时间 
restore log    d3 from bak3 with file=2,norecovery 
restore log    d3 from bak3 with file=3,norecovery 
restore log    d3 from bak3 with file=4,recovery,stopat=‘2003-08-15 11:29:00.000‘ 
---------------------------------------------------------------------- 
restore database d5 filegroup=‘FG2‘ from bak5 with file=4,norecovery --还原文件组备份 
restore log d5 from bak5 with file=5,norecovery 
restore log d5 from bak5 with file=7,recovery 
---------------------------------------------------------------------- 
restore headeronly from bak6                --还原文件备份 
restore database d5 file=‘d5_data3‘ from bak6 with file=6,norecovery 
restore log d5 from bak6 with file=7,norecovery 
restore log d5 from bak6 with file=9,recovery 
---------------------------------------------------------------------- 
restore database d5 from bak6 with replace    --删除现有数据库,从备份中重建数据库 
---------------------------------------------------------------------- 
create database d6            --move to将数据库文件移动到新位置 
on primary 
(name=d6_data, 
filename=‘E:\Program Files\Microsoft SQL Server\MSSQL\data\d6_Data.MDF‘, 
size=2MB) 
log on 
(name=d6_log, 
filename=‘E:\Program Files\Microsoft SQL Server\MSSQL\data\d6_log.ldf‘, 
size=2MB) 
go 
backupdatabase d6 to bak6 with init 
drop database d6 
restore database d6 from bak6 
with move ‘d6_data‘ to ‘e:\data\d6\d6_data.mdf‘, 
move ‘d6_log‘to ‘e:\data\d6\d6_log.ldf‘ 
sp_helpdb d6 
---------------------------------------------------------------------- 
3、分离与重连接数据库 
-------------------------------------- 
sp_detach_db ‘d6‘        
sp_attach_db ‘d6‘,‘e:\data\d6\d6_data.mdf‘,‘e:\data\d6\d6_log.ldf‘ 
-------------------------------------- 
sp_detach_db d6 
go 
create database d6 
on primary 
(filename=‘e:\data\d6\d6_data.mdf‘) 
for attach 
go 
---------------------------------------------------------------------- 
4、恢复损坏的系统数据库 
---------------------------------------------------------------------- 
1)先备份MASTER、MSDB 
2)停止SQL服务,将MASTER数据库文件删除或者重命名。这样,SQL服务将不能启动。 
3)系统数据库的还原 
----------------------------------------------- 
(1)如果SQL服务还能启动,则从备份中恢复系统数据库。 
(2)如果SQL服务不能启动,则需要重建系统数据库。 
使用SQL文件夹TOOLS\BINN目录下的Rebuildm.exe重建master数据库。 
(3)创建备份设备,指向以前的备份设备。 
(4)以单用户模式启动SQL 
cd programe files\microsoft sql server\mssql\binn 
sqlservr.exe -c -m 
(5)进查询分析器,从备份中恢复master数据库。 
restore database master from masterbak 
restore database msdb from disk=‘e:\bak\msdb.bak‘ 
MASTER还原后,SQL中用户数据库的信息也会恢复。 
(6)如果MASTER没有备份,则需要用sp_attach_db命令将用户数据库附加到新的MASTER数据库中。

 
 




































































































































































以上是关于sqlserver脚本备份固定多个数据库的主要内容,如果未能解决你的问题,请参考以下文章

SQLServer备份脚本

sqlserver2008数据库自动备份的sql脚本及使用bat命令执行脚本

sqlserver2008数据库自动备份的sql脚本及使用bat命令执行脚本

sqlserver导出数据两种方式:1.导出数据脚本 2.备份数据库

Bat脚本备份sqlserver 表结构存储过程函数指定表数据

sqlserver 备份脚本