当前位置: 首页 > 图文教程 > 数据库 > MSSQL > 丢失的数据忘记备份的处理方法[图文]

MSSQL
SQL Server中删除重复数据的几个方法
SQL Server 基础概念集
SQL Server导入导出
SQL SERVER实用技巧
sql server 常用函数
如何维护SQL Server的“交易日志”
SQL Server数据备份处理过程探讨
JSP中tomcat的SQL Server2000数据库连接池的配置
SQL Server服务器安装剖析
SQL Server 2005数据加密技术应用研究
SQL Server数据库的备份和恢复措施
SQL Server 2005性能测试实践
Jboss下MS SQL Server配置指导
Oracle和SQL Server 追求完美还是讲求实用
SQL Server服务器安装剖析
SQL Server:Oracle与SQL Server事务处理的比较
SQL Server:利用配置文件实现SQL Server与Oralce访问类的转换
SQL Server:测试SQL Server业务规则链接方法
SQL Server :SQL Server 2008高可用性解决方案优劣分析
SQLServer:数据库恢复

MSSQL 中的 丢失的数据忘记备份的处理方法[图文]


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-09-13   浏览: 78 ::
收藏到网摘: n/a

突然间数据库无缘无故损坏了,差异备份或事务日志备份在3点才会自动去做,那么如何将2点到2点40之间的数据恢复呢?这就需要通过备份尾部日志进行恢复了。 环境描述:
  某公司装了一台SQL Server数据库,为了保证数据库能够在出现故障时及时的修复,管理员做了备份操作,比如说完整备份+差异备份或者完整备份+事务日志备份,而且备份的时间是每隔6个小时做一次完整备份,在每天的1点、6点、12点、18点,6个小时之内是每隔1个小时做一次差异备份或事务日志备份,并且和计划任务结合在了一起。
  假如现在存在这样一种场景,在2点40分左右,突然间数据库无缘无故损坏了,差异备份或事务日志备份在3点才会自动去做,那么如何将2点到2点40之间的数据恢复呢?这就需要通过备份尾部日志进行恢复了。
  实施步骤:
  1、 首先创建一个数据库,并在数据库里创建一张表Dreamfire做测试用。
<a href='http://www.webjx.com/database/'><u>数据库</u></a>没有备份---应如何还原丢失的数据
2、 其次创建两个备份设备(备份数据存放的地方),一个存放完整备份的数据,一个存放差异备份的数据。做一次完整备份+差异备份,假如完整备份在1点做完整备份,2点做差异备份。

  先做完整备份:

  <a href='http://www.webjx.com/database/'><u>数据库</u></a>没有备份---应如何还原丢失的数据
<a href='http://www.webjx.com/database/'><u>数据库</u></a>没有备份---应如何还原丢失的数据

  <a href='http://www.webjx.com/database/'><u>数据库</u></a>没有备份---应如何还原丢失的数据
<a href='http://www.webjx.com/database/'><u>数据库</u></a>没有备份---应如何还原丢失的数据

  做完完整备份之后,然后在刚才创建的数据库的表中添加一条数据做测试用。

  然后通过差异备份数据库

  <a href='http://www.webjx.com/database/'><u>数据库</u></a>没有备份---应如何还原丢失的数据
突然间数据库无缘无故损坏了,差异备份或事务日志备份在3点才会自动去做,那么如何将2点到2点40之间的数据恢复呢?这就需要通过备份尾部日志进行恢复了。

 <a href='http://www.webjx.com/database/'><u>数据库</u></a>没有备份---应如何还原丢失的数据

  <a href='http://www.webjx.com/database/'><u>数据库</u></a>没有备份---应如何还原丢失的数据

3、 创建一张表为dbo.weibu,做测试用。假如这条记录是在2点到3点之间创建的。

  <a href='http://www.webjx.com/database/'><u>数据库</u></a>没有备份---应如何还原丢失的数据

  4、 模拟数据库丢失(删除刚才创建的xiaonuo数据库),然后通过完整备份+事务日志备份还原

  首先停止数据库的所有服务(也可以只停SQL Server服务),然后删除xiaonuo数据库,然后重启所有服务,并连接到数据库实例中可以看出刚才创建的数据库test里的表不存在了。

  <a href='http://www.webjx.com/database/'><u>数据库</u></a>没有备份---应如何还原丢失的数据
<a href='http://www.webjx.com/database/'><u>数据库</u></a>没有备份---应如何还原丢失的数据

  删除完数据库之后,然后启动服务,链接到数据库实例中,可以看到刚才创建的数据库xiaonuo里的数据全部丢失了。

  <a href='http://www.webjx.com/database/'><u>数据库</u></a>没有备份---应如何还原丢失的数据

  5、 备份尾部日志并还原。

  如果通过正常还原(完整备份+差异备份还原),只能还原dbo.Dreanfire这张表,并不能还原dbo.weibu这张表。这就需要在master数据库中备份数据库xiaonuo的尾部日志(删除xiaonuo数据库时,可不能连尾部日志也删除了),备份的时候,数据库选择“xiaonuo”,备份类型选择“事务日志”

<a href='http://www.webjx.com/database/'><u>数据库</u></a>没有备份---应如何还原丢失的数据

  注意:常规里一定要选择“追加到现有备份集”

  <a href='http://www.webjx.com/database/'><u>数据库</u></a>没有备份---应如何还原丢失的数据

  6、 进行完整备份+事务日志备份的还原

  注意:还原了时候,最后会多一条日志备份记录,也就是刚才在master数据库上做的关于xiaonuo数据库的尾部日志备份。

  还原完成之后,可以看到不但完整备份和差异备份的数据回来了,而且没有备份的数据也回来了。
<a href='http://www.webjx.com/database/'><u>数据库</u></a>没有备份---应如何还原丢失的数据

  <a href='http://www.webjx.com/database/'><u>数据库</u></a>没有备份---应如何还原丢失的数据