| 
  • Increase font size
  • Decrease font size
  • Default font size
  • default color
  • red color
  • green color
香农数据安全在线
Sep 11th
首 页 arrow 论 坛
论坛
欢迎您, 游客
登录注册.    忘记密码?
SQL Server日志文件丢失的恢复方法 (1 个人正在浏览) (1) 游客
到底部 发表回复
被收藏: 0
话题: SQL Server日志文件丢失的恢复方法

#5
admin (管理员)
管理员
帖子: -8
graphgraph
该会员已离线 点此观看该会员的个人资料
SQL Server日志文件丢失的恢复方法 4 年, 9 月 之前 评分: 1  
一、 概述<br /><br />   在应用系统中,数据库往往是最核心的部分,一旦数据库毁坏或损坏,将会带来巨大的损失,所以数据库的管理越来越重要。我们在做数据库管理与维护工作中,不可避免会出现各种各 的错误,本文针对数据库的日志文件丢失时如何利用MDF文件恢复数据库的方法进行了研究。 <br /><br />  二、 数据库的恢复<br /><br />  当数据库的主数据MDF文件完好无损时,在丢失了LDF文件的情况下,如何利用MDF文件恢复数据库?我们把SQL Server的日志文件分为两类:一类是无活动事务的日志,另一类是含活动事务的日志,根据不同的日志,采取不同的方法来恢复数据库。<br /><br />  1. 无活动事务的日志恢复<br /><br />  无活动事务的日志丢失时,我们很容易利用MDF文件直接恢复数据库,具体方法如下:<br /><br />  ①.分离被质疑的数据库,可用企业管理器中的&quot;分离数据库工具&quot;,或者用存储过程sp_detach_db分离数据库;<br /><br />  ②利用MDF文件附加数据库生成新的日志文件,可用企业管理器中的&quot;附加数据库&quot;的工具,或者用存储过程sp_attach_single_file_db附加数据库。<br /><br />  如果数据库的日志文件中含有活动事务,利用此方法就不能恢复数据库。<br /><br />  2. 含活动事务的日志恢复<br /><br />  含有活动事务的日志丢失时,利用上述方法就会出现&quot;数据库和日志文件不符合,不能附加数据库&quot;。对于这种情况下,我们采用如下方法:<br /><br />  ①新建同名数据库AAA,并设它为紧急模式<br /><br />  ·停止SQL Server服务器;<br /><br />  ·把数据库主数据MDF文件移走;<br /><br />  ·启SQL Server服务器,新建一个同名的数据库AAA; <br /><br />  ·停止SQL Server服务器,把移走的MDF文件再覆盖回来;<br /><br />  ·启动SQL Server服务器,把AAA设为紧急模式,不过默认情况下,系统表是不能随便修改的,必须首先设置一下使其能被修改,运行以下语句即可:<br /><br />Use Master<br />Go<br />sp_configure ’allow updates’,1<br />reconfigure with override<br />Go <br /><br />  接着运行以下语句,把AAA数据库设为紧急模式,即把Sysdatabases表中AAA数据库的status属性设为’37268’,就表示把AAA数据库处于紧急模式。<br /><br />update sysdatabases set status=32768 where hame=’AAA’ <br /><br />  如果没有报告什么错误,就可以进行以下操作。<br /><br />  ②设置数据库AAA为单用户模式,并检查数据库<br /><br />  ·重启SQL Server服务器;<br /><br />  ·把数据库AAA设为单用户模式<br /><br />Sp_dboption ’AAA’, ’single user’, ’true’ <br /><br />  ·运行以下语句,检查数据库AAA<br /><br />DBCC CHECKDB(’AAA’) <br /><br />  如果没有什么大的问题就可以把数据库的状态改回去。<br /><br />  ③还原数据库的状态<br /><br />  运行以下语句,就可以把数据库的状态还原:<br /><br />update sysdatabases set status=28 where name=’AAA’<br />sp_configure ’allow updates’,0<br />reconfigure with override<br />Go <br /><br />  如果没有什么大的问题,刷新一下数据库,数据库AAA又会出现在你面前,但目前恢复工作还没有做完,此时的数据库仍不能工作,还要进行下面的处理,才能真正恢复。<br /><br />  ④利用DTS的导入导出向导,把数据库AAA导入到一个新建数据库BBB中<br /><br />  ·新建一个数据库BBB;<br /><br />  ·右击BBB,选择IMPORT功能,打开导入向导;<br /><br />  ·目标源选择&quot;在SQL Server数据库之间复制对象和数据库&quot;,这样可以把表结构,数据视图和存储过程导入到BBB中<br /><br />  ·再用此功能把BBB库替换成原来的AAA库即可。<br /><br />  到此为止,数据库AAA就完全恢复。<br /><br />  三、 小结<br /><br />  日志文件丢失是一件非常危险的事情,很有可能你的数据库彻底毁坏。SQL Server数据库的恢复都是靠日志文件来完成,所以无论如何都要保证日志文件的存在,它至关重要。为了使我们的数据库万无一失,最好采用多种备份方式相结合,所以我们要从心里重视数据 的管理与维护工作。 <br /><br />*****************************************************************************************************************************<br /><br />实现附加数据库 <br /> <br />---------------------------<br />--Microsoft SQL-DMO (ODBC SQLState: 42000)<br />---------------------------<br />--错误 1813: 未能打开新数据库 &#039;故障查询&#039;。CREATE DATABASE 将终止。<br />--设备激活错误。物理文件名 &#039;I:Microsoft SQL ServerMSSQLdata故障查询.ldf&#039; 可能有误。<br />---------------------------<br />--确定&nbsp; <br />---------------------------<br /><br />--1、更改 原 故障查询.mdf 文件的名称 为 故障查询1.mdf<br />--2、新建同名数据库 故障查询,其物理名称为 故障查询.mdf、故障查询.ldf<br />--3、停止MSSQLSERVER服务,删除步骤2创建的2个文件,并改名 故障查询1.mdf 为 故障查询.mdf<br />--4、启动MSSQLSERVER服务,此时 故障查询 数据库肯定是‘置疑’的<br />--5、设置数据库允许直接操作系统表;可以右键选服务器,在[服务器设置]选项卡的[服务器行为]里面更改。<br />use master<br />go<br />sp_configure &#039;allow updates&#039;,1<br />go<br />reconfigure with override<br />go<br />---------------------------------------------------------------------------------------------<br />--6、设置 故障查询&nbsp; 数据库为紧急修复模式<br />update sysdatabases set status=-32768 where dbid=db_id(&#039;故障查询&#039<br />go<br />--7、重建 故障查询&nbsp; 数据库的日志文件,若不能锁定请停止服务并再次打开服务,然后用QA重试<br />dbcc rebuild_log(&#039;故障查询&#039;,&#039;I:Microsoft SQL ServerMSSQLData故障查询.ldf&#039<br />go<br />--8、检查数据库的一致性<br />dbcc checkdb(&#039;故障查询&#039<br />go<br />--9、设置数据库 故障查询 为 正常 模式<br />sp_dboption &#039;故障查询&#039;,&#039;dbo use only&#039;,&#039;false&#039;<br />go<br />----------------------------------------------------------------------------------------------<br />--10、取消数据库直接操作系统表<br />sp_configure &#039;allow updates&#039;,0<br />go<br />reconfigure with override<br />go<br /> <br /><br />这个特别好使,我就是它的受益者之一,幸亏这个技术,不然公司损失就大了
 
向版主举报   已记录 已记录  
 
  只有注册会员才能发帖
#254
数据库丢失! (会员)
Fresh Boarder
帖子: 0
graphgraph
该会员已离线 点此观看该会员的个人资料
Re: SQL Server日志文件丢失的恢复方法 4 年, 1 月 之前 评分: 0  
不知道有没有用过金蝶的ERP,出现了同样的问题但是我在恢复完以后不能打开表,提示823!
 
向版主举报   已记录 已记录  
  只有注册会员才能发帖
#255
香农数据 (会员)
Senior Boarder
帖子: 43
graph
该会员已离线 点此观看该会员的个人资料
Re: SQL Server日志文件丢失的恢复方法 4 年, 1 月 之前 评分: 0  
可能是数据库文件有问题
 
向版主举报   已记录 已记录  
 
  只有注册会员才能发帖
到顶部 发表回复