如何在SQL Server数据库中完全修复MDF文件

译文
数据库 SQL Server
众所周知,由于数据库文件里存储了大量重要的信息,因此对于所有用户来说都是至关重要的。让我们一起来了解一下如何通过手动和专业的方法,修复那些被损坏的SQL数据库文件吧。

【51CTO.com快译】引言:众所周知,由于数据库文件里存储了大量重要的信息,因此对于所有用户来说都是至关重要的。让我们一起来了解一下如何通过手动和专业的方法,修复那些被损坏的SQL数据库文件吧。

如今微软的SQL Server可谓是最常用的关系型数据库之一了。鉴于其先进的内部结构和高可靠性,大多数组织都选用SQL Server数据库来存储所有关键业务的数据。但是有时候,一些诸如病毒感染、操作系统故障、文件系统损坏之类的状况会使得SQL数据库受到损坏,以至于存储在其中的所有数据都变得无法访问。然而,在真实的场景中,我们在损坏的SQL Server里修复各种.mdf文件,却并非是一件容易的事。

一般用户可以通过手动的方法,来逐步修复SQL数据库中损坏的MDF文件,但是该方法并不可靠,因为它无法保证数据能够被完全地恢复。不过,也有类似SysTools SQL Recovery这样的第三方工具,声称可以完美的方式修复.mdf文件。

因此在本文中,我们将和您讨论修复受损SQL数据库的最佳解决方法。不过在开始之前,让我们先来了解一下SQL数据库受损的背后原因。

SQL数据库受损的背后原因

SQL数据库受损的背后原因有许多种。众所周知,SQL数据库的各个MDF文件其实是一些主要的数据库文件,它们存储着所有用户的数据,因此任何MDF文件的损坏都可能会导致整个数据库的崩溃。可见,我们需要首先来了解MDF文件受损背后的所有可能原因:

  • MDF文件所在存储介质的损坏。
  • 如果用户将SQL数据库存储在一个压缩的文件夹中,那么MDF文件就可能因此而被损坏。
  • 在某个SQL Server帐号下,所进行的任何修改或变更。
  • 某个用户可能对数据进行错误地删除。
  • 由于文件头的损坏,所导致的MDF文件受损。
  • 磁盘驱动器受损。
  • SQL数据库正在被写入使用时发生了网络故障,则可能会导致MDF文件的损坏。
  • 导致MDF文件损坏的其他可能原因还包括:病毒攻击、硬盘故障、系统异常关机和突然断电等。

因此,如果MDF文件被损坏,那么SQL数据库就会变得不可访问。另外,如果用户试图去访问已损坏的数据库,则可能会看到一些错误提示消息。下面我们列出了一些最常见的错误消息:

  • MDF文件所在存储介质的损坏。
  • 如果用户将SQL数据库存储在一个压缩的文件夹中,那么MDF文件就可能因此而被损坏。
  • 元数据的损坏错误。
  • 用户可能对数据进行错误地删除。
  • SQL Server中的Msg 823 / Msg 824 / Msg 825(读取重试)错误。

除此之外,用户还可能在访问受损的SQL数据库时,遇到其他类型的错误提示。可见,数据库管理员应当立即采取措施,以防止任何类型的数据丢失。

如何手动修复MDF文件

我们可以用几种手动的方法来修复受损的SQL数据库,但是这些手动解决方法是无法保证数据库能被完全恢复的。

用户可以使用SQL Server的NDF文件(一些日志文件)来进行恢复。但是在大多数损坏的案例中,单凭日志文件是不足以恢复数据库的。因为有时候在一些被严重损坏的情况下,其对应的备份文件也同样遭到了破坏。

另一种可能修复和复原受损SQL数据库的方式是使用数据库控制台命令,例如:DBCC CHECKDB。该命令对于修复SQL Server数据库中的轻度损坏问题是非常有效的。

用DBCC CHECKDB来修复受损MDF文件的步骤

首先,您需要在受损的SQL数据库上运行DBCC CHECKDB,请执行如下的命令:

 

  1. DBCC CHECKDB (Name_of _corrupt _database) 

注意:您也可以为DBCC CHECKDB定义诸如no_infomsgs和infomsgs的选项参数。

在此之后,您就需要开始检查索引ID了。

情况1:如果索引ID>1,则立刻丢弃它、并重新创建。

情况2:如果索引ID为0或1,则使用适当的修复选项,如:repair_rebuild、repair_fast或repair_allow_data_loss,来再次运行DBCC CHECKDB。

 

  1. DBCC CHECK (name_of_corrupt_database, repair_fast)  
  2. DBCC CHECK (name_of_corrupt_database, repair_rebuild)  
  3. DBCC CHECK (name_of_corrupt_database, repair_allow_data_loss) 

 

至此为确保修复了所有损坏,请再次运行DBCC CHECKDB。如果在name_of_your_corrupt_database中显示为0个分配错误和0个一致性错误,则大功告成。

如果手动方法失败了呢?

由于其自身的局限性,手动解决方法并不总是万无一失的。例如,MDF文件被严重损坏时,手动修复往往会以失败而告终。而且,手动解决方法需要用户有较强的技术能力。因此,我们建议使用一些可靠的第三方软件,来修复受损的SQL数据库。SQL数据库恢复程序(SQL Database Recovery Program)是一款最佳的实用程序,它可以修复MDF文件中任何类型的损坏问题。

SQL恢复工具能够同时修复MDF和NDF两种受损的SQL数据库文件。它是一款无风险的软件,可以恢复存储在各种表格、规则、触发器、以及函数中的所有数据项。除此之外,您只需点击几次该软件,便可完成数据库的修复,而绝不浪费任何时间。

修复受损MDF文件的具体步骤

下载并在本地机器上运行SQL恢复程序。

 SysTools SQL恢复工具

在此之后,您可以通过定位,来选择并打开受损的SQL数据库文件(.mdf文件)。

 选择损坏的MDF文件

选择扫描模式,然后单击确定

 扫描模式

该工具将会为您提供一个存储在受损MDF文件中的数据项的预览。

 查看MDF文件

点击导出,以保存要恢复的数据库。

 导出MDF数据库

结论

由于数据库文件里存储了大量重要的信息,因此对于所有用户来说都是至关重要的。然而SQL数据库中任何类型的损坏问题,都可能会给用户造成巨大的麻烦。为了应对和克服各种可能出现的问题,我们通过上述的讨论,向您提供了运用手动和专业的解决方法,来修复那些受损的SQL数据库文件。

原文标题:How to Repair MDF Files in SQL Server Database,作者:John Walker

【51CTO译稿,合作站点转载请注明原文译者和出处为51CTO.com】

责任编辑:庞桂玉 来源: 51CTO
相关推荐

2011-08-03 14:50:26

SQL Server数Visual Stud.MDF数据库文件

2011-03-11 13:26:23

SQL Server数导入数据

2023-09-05 00:06:45

2010-07-15 17:28:50

SQL Server

2011-03-02 17:41:28

2011-03-18 09:48:32

2010-07-15 15:37:13

SQL Server数

2011-07-28 11:44:46

SQL Server数合并表格数据

2011-03-15 09:55:07

SQL Server2数据库崩溃还原数据库

2011-03-24 11:14:46

2011-04-15 09:47:50

2010-03-26 09:46:32

SQL Server

2011-03-15 09:52:40

SQL Server2数据库恢复系统

2011-03-30 13:24:23

SQL Server数故障修复

2015-10-30 14:00:33

adosybaseodbc

2010-07-01 15:02:29

SQL Server数

2010-10-19 14:19:07

SQL Server恢

2010-07-08 11:05:14

SQL Server数

2011-08-09 12:27:16

SQL Server tempdb

2021-05-08 14:07:26

SQLServer数据库
点赞
收藏

51CTO技术栈公众号