完整备份: 备份全部选中的文件和文件夹,并不依赖文件的存档属性来确定备份哪些文件。(在备份过程中,任何现有的标记都被清除,每个文件都被标记为已备份,换言之,清除存档属性),完全备份也叫完整备份。
差异备份: 差异备份是针对完整备份:备份上一次完整备份后发生变化的所有文件。(差异备份过程中,只备份有标记的那些选中的文件和文件夹。它不清除标记,即:备份后不标记为已备份文件,换言之,不清除存档属性,直到下一次完整备份为止)。
完整+差异备份的优缺点比较:
优点:
1. 占用的空间较小,在一个周期内,只需要保存一份完整备份,其它都是差异备份;
2. 在恢复数据时,只需要恢复一份完整备份 + 最新一次的差异备份;
3. 虽然备份数据需要较多的时间,但还原数据使用较少的时间。
缺点:
- 若完整备份的资料丢了,则所有的备份就全完蛋了!所以要特别注意对完整备份文件的保存;
本文中环境为SQL2012.
例子
1. 备份
1.1 创建数据库TestBackup
1.2 创建表TestTable
CREATE TABLE [dbo].[TestTable]( [id] [int] NULL, [name] [nvarchar](10) NULL ) ON [PRIMARY]
1.3 插入数据
insert into [TestTable] values (1,'full').
我们把此时的点叫做 时间点1
1.4 备份数据库,选择全备份
BACKUP DATABASE [TestBackup] TO DISK = N'D:\database backup\TestBackupDB-full.bak' WITH NOFORMAT, NOINIT, NAME = N'TestBackup-Full Database Backup', SKIP, NOREWIND, NOUNLOAD, STATS = 10 GO
或者如下图
1.5 插入数据
insert into [TestTable] values (2,'diff1')
我们把此时的点叫做 时间点2
1.6 做第一个差异备份
BACKUP DATABASE [TestBackup] TO DISK = N'D:\database backup\TestBackupDB-diff1.bak' WITH DIFFERENTIAL , NOFORMAT, NOINIT, NAME = N'TestBackup-Differential Database Backup', SKIP, NOREWIND, NOUNLOAD, STATS = 10 GO
或者如下图
1.7 插入数据
insert into [TestTable] values (3,'diff2')
我们把此时的点叫做 时间点3
1.8 做第二个差异备份
BACKUP DATABASE [TestBackup] TO DISK = N'D:\database backup\TestBackupDB-diff2.bak' WITH DIFFERENTIAL , NOFORMAT, NOINIT, NAME = N'TestBackup-Differential Database Backup', SKIP, NOREWIND, NOUNLOAD, STATS = 10 GO
2 还原(没有分区)
2.1 还原到时间点1
就是将全备份直接还原,这里不多叙述.
2.2 还原到时间点2
2.2.1做全备份的还原
RESTORE DATABASE [TestBackup-Re] FROM DISK = N'D:\database backup\TestBackupDB-full.bak' WITH FILE = 1, MOVE N'TestBackup'
TO N'C:\Program Files\Microsoft SQL Server\MSSQL11.SQL2012\MSSQL\DATA\TestBackup-Re.mdf',
MOVE N'TestBackup_log' TO N'C:\Program Files\Microsoft SQL Server\MSSQL11.SQL2012\MSSQL\DATA\TestBackup-Re_log.ldf', NORECOVERY, NOUNLOAD, STATS = 5
注意,必须加选项NORECOVERY.
或如下图
在这里,我们把数据还原成了另外一个数据库,名字叫TestBackup-Re.加了NORECOVERY的数据库还原后是不能直接使用的.如下图(显示正在还原)
2.2.2差异还原
选择TestBackupDB-diff1.bak文件,还原到TestBackup-Re,
RESTORE DATABASE [TestBackup-Re] FROM DISK = N'D:\database backup\TestBackupDB-diff1.bak' WITH FILE = 1, MOVE N'TestBackup' TO N'C:\Program Files\Microsoft SQL Server\MSSQL11.SQL2012\MSSQL\DATA\TestBackup-Re.mdf', MOVE N'TestBackup_log' TO N'C:\Program Files\Microsoft SQL Server\MSSQL11.SQL2012\MSSQL\DATA\TestBackup-Re_log.ldf', RECOVERY, NOUNLOAD, STATS = 5
注意mdf和log文件的命名需要手动更改和TestBackup-Re一致.
还原后,查看[TestTable]表,表中数据为时间点2的数据.
2.3 还原到时间点3
2.3.1做全备份的还原(同2.2.1)
把数据库名字改为TestBackup-Re2
RESTORE DATABASE [TestBackup-Re2] FROM DISK = N'D:\database backup\TestBackupDB-full.bak' WITH FILE = 1, MOVE N'TestBackup' TO N'C:\Program Files\Microsoft SQL Server\MSSQL11.SQL2012\MSSQL\DATA\TestBackup-Re2.mdf', MOVE N'TestBackup_log' TO N'C:\Program Files\Microsoft SQL Server\MSSQL11.SQL2012\MSSQL\DATA\TestBackup-Re2_log.ldf', NORECOVERY, NOUNLOAD, STATS = 5
下图
2.3.2差异还原
选择TestBackupDB-diff2.bak文件,还原到TestBackup-Re2,注意mdf和log文件的命名需要手动更改和TestBackup-Re2一致.
RESTORE DATABASE [TestBackup-Re2] FROM DISK = N'D:\database backup\TestBackupDB-diff2.bak' WITH FILE = 1, MOVE N'TestBackup' TO N'C:\Program Files\Microsoft SQL Server\MSSQL11.SQL2012\MSSQL\DATA\TestBackup-Re2.mdf', MOVE N'TestBackup_log' TO N'C:\Program Files\Microsoft SQL Server\MSSQL11.SQL2012\MSSQL\DATA\TestBackup-Re2_log.ldf', RECOVERY, NOUNLOAD, STATS = 5
还原后,查看[TestTable]表,表中数据为时间点3的数据.
3 还原(有分区)
来,在实践中,有一个数据有分区,按照2中所属分步操作失败了.
ITMP2每天都备份,每天删除一个老的分区,每天创建一个新的分区.按照上面的步骤,先做全备份的还原,在做差异备份的还原.报错如下:
Unable to create restore plan due to break in the LSN chain.--(版本为sql2012)
后来试了几次,通过如下方法解决:
在选择Source中Device的时候,选择多个文件:选择全备份和最近一个差异备份,如下图
选项Options选择默认的restore with recovery.
备份成功后,和最后一个差异备份的分区文件和数据完全相同(即删除的分区文件新建的分区文件相同,其他数据也相同)