前言:最近项目接近了尾声,随之而来的是维护问题,当然涉及到数据库的数据维护,通过资料和实际操作整理有关误操作后根据日志还原数据库。 前提:①必须有数据库的完整备份(做个备份计划);②数据库恢复模式是完整的(FULL)。 步骤:①发现误操作时,记录下时
前言:最近项目接近了尾声,随之而来的是维护问题,当然涉及到数据库的数据维护,通过资料和实际操作整理有关误操作后根据日志还原数据库。
前提:①必须有数据库的完整备份(做个备份计划);②数据库恢复模式是完整的(FULL)。
步骤:①发现误操作时,记录下时间点date并备份日志文件(备份脚本:USE master BACKUP LOG 数据库 TO disk=N'G:cclog.bak' WITH NORECOVERY);
②还原数据库(还原脚本:USE master RESTORE DATABASE 数据库 FROM DISK = N'G:cc.bak' WITH NORECOVERY, REPLACE);
③还原日志(还原日志脚本:USE master RESTORE LOG 数据库 FROM DISK = N'G:cclog.bak' WITH STOPAT = N'date' , RECOVERY);
④以上3步都操作成功后则还原成功,此时查看数据库发现误删除操作的数据又回来了。
说明:①"NORECOVERY"是用来备份尾日志的,这样备份日志的时候数据库处于恢复状态,别的进程就不能再访问数据库,日志就不会再增加了,这样在还原的时候就可以正常恢复了。还原备份的时候如果想同时还原之后的日志,必须加上Norecovery才可以还原日志。
②时间点"date"格式为"M/D/YYYY H:m:s PM",是12小时制,,例如:1/23/2014 1:17:10 PM表示2014年1月23号下午1点17分10秒,此时间点只要在误操作前就可以。