SQL Server日志文件数据丢失的恢复方法
<font style="font-size: 15px;" id="zoom" class="fonttitle1"><strong> 一、 概述<br /><br /></strong> 在应用系统中,数据库往往是最核心的部分,一旦数据库毁坏或损坏,将会带来巨大的损失,所以数据库的管理越来越重要。我们在做数据库管理与维护工作中,不可避免会出现各种各样的错误,本文针对数据库的日志文件丢失时如何利用MDF文件恢复数据库的方法进行了研究。 <br /><br /> <b>二、 数据库的恢复</b><br /><br /> 当数据库的主数据MDF文件完好无损时,在丢失了LDF文件的情况下,如何利用MDF文件恢复数据库?我们把SQL Server的日志文件分为两类:一类是无活动事务的日志,另一类是含活动事务的日志,根据不同的日志,采取不同的方法来恢复数据库。<br /><br /> 1. 无活动事务的日志恢复<br /><br /> 无活动事务的日志丢失时,我们很容易利用MDF文件直接恢复数据库,具体方法如下:<br /><br /> ①.分离被质疑的数据库,可用企业管理器中的"分离数据库工具",或者用存储过程sp_detach_db分离数据库;<br /><br /> ②利用MDF文件附加数据库生成新的日志文件,可用企业管理器中的"附加数据库"的工具,或者用存储过程sp_attach_single_file_db附加数据库。<br /><br /> 如果数据库的日志文件中含有活动事务,利用此方法就不能恢复数据库。<br /><br /> 2. 含活动事务的日志恢复<br /><br /> 含有活动事务的日志丢失时,利用上述方法就会出现"数据库和日志文件不符合,不能附加数据库"。对于这种情况下,我们采用如下方法:<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 /><table width="90%" bordercolor="#cccccc" border="1" bgcolor="#e3e3e3" align="center">
<tbody>
<tr>
<td>Use Master<br />Go<br />sp_configure ’allow updates’,1<br />reconfigure with override<br />Go</td></tr></tbody></table><br /> 接着运行以下语句,把AAA数据库设为紧急模式,即把Sysdatabases表中AAA数据库的status属性设为’37268’,就表示把AAA数据库处于紧急模式。<br /><br />
<table width="90%" bordercolor="#cccccc" border="1" bgcolor="#e3e3e3" align="center">
<tbody>
<tr>
<td>update sysdatabases set status=32768 where hame=’AAA’</td></tr></tbody></table><br /> 如果没有报告什么错误,就可以进行以下操作。<br /><br /> ②设置数据库AAA为单用户模式,并检查数据库<br /><br /> ·重启SQL Server服务器;<br /><br /> ·把数据库AAA设为单用户模式<br /><br />
<table width="90%" bordercolor="#cccccc" border="1" bgcolor="#e3e3e3" align="center">
<tbody>
<tr>
<td>Sp_dboption ’AAA’, ’single user’, ’true’</td></tr></tbody></table><br /> ·运行以下语句,检查数据库AAA<br /><br />
<table width="90%" bordercolor="#cccccc" border="1" bgcolor="#e3e3e3" align="center">
<tbody>
<tr>
<td>DBCC CHECKDB(’AAA’)</td></tr></tbody></table><br /> 如果没有什么大的问题就可以把数据库的状态改回去。<br /><br /> ③还原数据库的状态<br /><br /> 运行以下语句,就可以把数据库的状态还原:<br /><br />
<table width="90%" bordercolor="#cccccc" border="1" bgcolor="#e3e3e3" align="center">
<tbody>
<tr>
<td>update sysdatabases set status=28 where name=’AAA’<br />sp_configure ’allow updates’,0<br />reconfigure with override<br />Go</td></tr></tbody></table><br /> 如果没有什么大的问题,刷新一下数据库,数据库AAA又会出现在你面前,但目前恢复工作还没有做完,此时的数据库仍不能工作,还要进行下面的处理,才能真正恢复。<br /><br /> ④利用DTS的导入导出向导,把数据库AAA导入到一个新建数据库BBB中<br /><br /> ·新建一个数据库BBB;<br /><br /> ·右击BBB,选择IMPORT功能,打开导入向导;<br /><br /> ·目标源选择"在SQL Server数据库之间复制对象和数据库",这样可以把表结构,数据视图和存储过程导入到BBB中<br /><br /> ·再用此功能把BBB库替换成原来的AAA库即可。<br /><br /> 到此为止,数据库AAA就完全恢复。<br /><br /> <b>三、 小结</b><br /><br />
日志文件丢失是一件非常危险的事情,很有可能你的数据库彻底毁坏。SQL
Server数据库的恢复都是靠日志文件来完成,所以无论如何都要保证日志文件的存在,它至关重要。为了使我们的数据库万无一失,最好采用多种备份方式相
结合,所以我们要从心里重视数据库的管理与维护工作。</font> 又一方式,偶测试过的:
先建一个同名的数据库,然后把sql停止,再把.mdf文件复制到data目录,同时删除.ldf文件,再远行sql,这样做完后,数据库处理“置疑”状态,然后用下面的语句修复,如果问题不大的话,应该是可以解决的。
SP_CONFIGURE 'ALLOW UPDATES',1 RECONFIGURE WITH OVERRIDE
update master..sysDatabases set status = 32768 where name = '你的数据库名'
DBCC REBUILD_LOG ('你的数据库名', '日志文件路径' )
update sysDatabases set status = 0 where name = '你的数据库名'
restore Database 你的数据库名 WITH RECOVERY
sp_dboption '你的数据库名', 'single user', 'true'
DBCC CHECKDB ('你的数据库名',REPAIR_FAST) with no_infomsgs
sp_dboption '你的数据库名', 'single user', 'false'
每一句都单独执行,如果dbcc有问题,还要用其它dbcc语句修复。
DBCC CHECKDB('你的数据库名',REPAIR_ALLOW_DATA_LOSS)
--DBCC CHECKDB('你的数据库名',REPAIR_REBUILD)
--DBCC CHECKDB('你的数据库名') with PHYSICAL_ONLY
页:
[1]