上次我们提到的第一类后悔药就是日常的备份了.可以通过定时执行任务来降低工作的复杂度.但是仍然会在恢复的时候耗费较多时间.
而对于平时的一些小的数据更新,比如在一个上百GB大小的库中操作一条数据,如果仅需要恢复这一条数据就要恢复整个表,那么花费的代价就太大了.
那么有什么办法能够解决呢?
那就是本次要给大家介绍的第二类后悔药-->快照
对于快照,可以认为就类似于一张数据库在指定时间点的一个相片,里面包含了数据库在指定的那个时刻的所有信息和状态,后续的任何操作不影响快照中的信息状态.
下面我们上药方:
USE [master]
GO
DECLARE @DBName NVARCHAR(50);
DECLARE @TodayDate NVARCHAR(10);
DECLARE @filePath NVARCHAR(200);
DECLARE @SQL NVARCHAR(800);
SET @DBName = 'DataBaseName' ----在此修改需要建快照的库名即可
SET @TodayDate = REPLACE(CONVERT(NVARCHAR(10),GETDATE(),120),'-',''); --获取当前日期拼入快照名称中
SELECT @filePath = REPLACE(filename,'templog.ldf','') FROM [tempdb].sys.[sysfiles] WHERE [groupid] = 0 --获取tempdb的日志文件所在路径作为快照文件存放路径
SET @SQL = N'CREATE DATABASE ' + @DBName + '_' + @TodayDate + ' ON ( NAME = ' + @DBName + ', FILENAME = ''' + @filePath + @DBName + '_' + @TodayDate + '.ss'') AS SNAPSHOT OF ' + @DBName + ';'
--PRINT @SQL;
EXEC(@SQL);
GO
通过上面的SQL,修改对应的库名就可以在tempdb存放的目录下生成对应的快照文件,并且在数据库中也能看到指定的快照库名DataBaseName_20yymmdd
,可以把这个快照当做一个数据库进行SQL语句的访问操作,但是快照是只读的,无法进行数据的更新和结构的变更,包括账号权限也无法进行调整.
如果需要恢复某一条数据,那就可以直接读出快照中的数据,然后替换现有表中的对应数据(删除,标识插入).
如果需要恢复整个库,那就通过下面的SQL来进行:
特别注意:这个恢复操作将丢失所有快照新建后对目标数据库的所有操作信息,请确认你自己清楚的知道到底会发生什么再进行操作!!!!!!!
USE master
GO
RESTORE DATABASE DataBaseName FROM DATABASE_SNAPSHOT = 'DataBaseName_20yymmdd';
GO
最后提醒:快照在新建的时候,快照文件的大小会和数据文件一样大,但是由于是系数文具,实际占用的空间很小,当数据库继续被使用的时候,快照文件会随着数据量的差异而越来越大,因此定期清理不需要再使用的快照文件是很有必要的.
感谢各位认真学习,两类药剂已经教给大家了,什么样的场景下使用什么样的方案就需要各位在实际的操作过程中根据情况来判断了.
祝大家永远用不上后悔药!~~