三、备份事务日志
我们用【备份日志尾部】的方法来恢复刚才被删除的数据。在操作前同样需要关闭当前所有连接。
具体步骤如下:选中数据库AdventureWorks——右键【任务】——【备份】,在弹出的对话框中将备份类型选为【事务日志】,如图8:
图8
点击左侧菜单栏的【介质选项】,做如图9的配置,在点击确定之前请再次确认是否有用户连接当前数据库,本地用户请将所有使用到该数据库的页面都关闭。
图9
待提示备份完成后,数据库会出现【正在还原...】字样,如图10:
图10
四、开始还原
首先我们要还原最近完整备份的那个备份文件,由于日志备份的特性,只认最后一次备份,所以要选择最新的那次,否则还原不了。具体操作如下:
右键AdventureWorks——【任务】——【还原】——【数据库】,在弹出的界面中做如图11的配置,只勾选组件为数据库的那个备份文件。
图11
点击左侧菜单栏【选项】做图12的配置,将恢复状态改完【RESTORE WITH NORECOVERY】:
图12
点击确定后待数据库还原成功即可进行下一步操作。
刚才我们已经还原了数据文件,下面我们继续还原日志文件。操作如下:
右键AdventureWorks——【任务】——【还原】——【事务日志】,按图13作如下配置:
图13
我们是在16:09分删除数据的,将时间点提前一分钟到16:08分。这里不用太在意,只要把时间点指定到你误删除的时间之前即可。
由于日志尾部备份都是最后一个备份文件,所以这里菜单栏的【选项】部分请按如图14做配置:
图14
待一切检查就绪后,点击确定即可开始回滚未提交的事务日志了。
五、检查是否恢复成功
输入查询语句,查询TEST中的数据。
USE AdventureWorks GO SELECT * FROM TEST
结果如图15
图15
可以看到正是我们刚才删除前的数据。至此,整个被删除的数据即完全恢复了。
六、方法局限性
此方法有一定的局限性
首先,就是要求数据的恢复模式是【完整】的,如果之前一直是【简单】模式,此方法不适用
其次,需要有一次完整的备份文件,如果你是管理数据库的,请做好每周一次完整备份的策略。
再次,如果你发现误操作以后还有很多人做了操作,那么你还原成功后,别人的操作就会冲掉,所以发生误操作后,要马上停止别人对数据库的操作。
最后,这个方法要对数据库独占,所以你想偷偷恢复是不行的了,勇敢承认错误吧。
PS:以上操作均是实验截图,请严格按照指引操作!