|
|
|
|
移动端

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

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

作者:陈峻编译来源:51CTO|2018-03-06 09:30

【新品产上线啦】51CTO播客,随时随地,碎片化学习

【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】

【编辑推荐】

  1. Java如何连接MySQL数据库进行操作
  2. SQL查询提速秘诀,避免锁死数据库的数据库代码
  3. 你应该使用NoSQL数据库、SQL数据库还是两者都用?
  4. 分布式数据库正连升三级
  5. 3 月全球数据库排名发布:PostgreSQL 再迎暴涨
【责任编辑:庞桂玉 TEL:(010)68476606】

点赞 0
分享:
大家都在看
猜你喜欢

读 书 +白菜送彩金大全

Microsoft SQL Server 2005 技术内幕:T-SQL查询

本书是Inside Microsoft SQL Server 2005系列四本著作中的一本。它详细介绍了T-SQL的内部构造,包含了非常全面的编程参考。它提供了使用Tra...

订阅51CTO邮刊

点击这里查看样刊

订阅51CTO邮刊
博聚网