SQL Server数据库恢复教程

SQL Server是一个可扩展的、高性能的、为分布式客户机/服务器计算所设计的数据库管理系统,实现了与WindowsNT的有机结合,提供了基于事务的企业级信息管理系统方案。本次需要进行数据恢复的服务器是一台r520型号存储,共有7块SAS硬盘分别组成RAID1和RAID5两组磁盘阵列。

主要SQL Server数据库存放在C盘中,在使用过程中,客户发现C盘容量即将占满,于是将数据库路径指向了D盘,在D盘生成了一个.ndf文件。

客户在继续使用了大约10天之后,数据库出现故障,连接失效,无法正常附加查询。在遇到这种情况是应该如何进行正确操作呢?

【备份数据】

考虑到数据的安全性以及可还原性,在做数据恢复之前需要对所有源数据做备份,以防万一其他原因导致数据无法再次恢复。使用dd命令或winhex工具将所有磁盘都镜像成文件。

【故障分析】

首先分析故障原因:由于数据库文件所在磁盘容量不足,导致数据库无法继续正常运行,出现逻辑错误;

再分析RAID组结构:客户服务器上共7块300G硬盘,其中2块硬盘做RAID 1,用于安装操作系统,其余5块硬盘做RAID 5存放数据。分析RAID 1和RAID 5的相关结构,重组虚拟出RAID 1和RAID 5,查看其中数据。

再分析原始数据库文件:由于客户在数据库发生故障之后,进行过多次数据库恢复尝试,并且每一次尝试都是在源环境下进行的,导致原始数据库文件被更改覆盖,并且磁盘空间被多次复写,无法使用尝试恢复之后的数据库文件进行修复。询问客户得知,客户在数据库发生故障的时候,备份过一分原始的故障数据库文件。

【数据库修复】

从虚拟出的RAID 5空间中将客户之前备份的数据库文件拷贝出来,尝试在数据库中附加,附加失败。错误提示主数据库文件和次级数据库文件不匹配,查看.ndf文件底层,发现.ndf文件中几乎没有数据,尝试取消.mdf文件和.ndf文件之间关联,只用.mdf文件进行附加。

尝试后发现,只用.mdf文件附加时也发生错误,但是错误提示改变。

此时错误提示日志文件(.ldf)和数据库文件(.mdf)不匹配。之后对数据库尝试进行无数据库附加,附加成功。但是发现数据库系统表损坏,无法正常使用。对数据库的系统表尝试修复,但由于系统表损坏过于严重,无法修复。

【数据库记录提取】

解析数据库文件中的数据库记录,编写相应的程序提取数据库文件中的数据库记录。根据客户以前的数据库备份获取数据库中的表结构,重构表结构并肩提取出的数据库记录导入到新的表中,进行数据验证,如数据没有问题,即本次数据恢复成功。

【北亚数据恢复小贴士】

在数据库使用过程中,要合理分配数据库文件所在的磁盘空间,及时清理垃圾数据,保证数据库的正常及安全运行,如遇到故障情况时,当不知道如何正确操作时,请及时联系相关专业数据恢复工程师进行数据恢复操作。

(0)

相关推荐

  • SQL SERVER数据库怎么恢复

    在用SQL SERVER数据库的时候免不了遇到数据库恢复,这里小编和大家一起来学习一下两种SQL SERVER数据库恢复的情况:1,有bak文件的数据库恢复:2,有mdf,ldf数据库文件的恢复.首先 ...

  • 多种SQL Server数据库备份方法的精细讲述教程

    本文假定您 能熟练使用SQL Server EntERPrise Manager(SQL Server企业管理器)和SQL Server Quwey Analyser(SQL Server查询分析器) ...

  • SQL server数据库安装步骤教程

    下面分享一下SQL server数据库的安装步骤,希望对大家有所帮助! 操作方法 01 打开SQL server数据库安装包,如下图. 02 点击开始安装------运行程序,如下图. 03 开始安装 ...

  • SQL Server数据库中的表和视图怎么导出?

    SQL Server已有数据库中的数据想要导出来,该怎么导出呢?下面我们就来看看详细的教程. 1.打开SQL Server,找到需要导出的数据库. 2.在需要导出的数据库上右击,选择任务选项中的导出数 ...

  • Heidisql如何连接sql server数据库并做增删改操作?

    Heidisql工具是一个功能强大的数据库连接工具,功能齐全.操作简单.用heidisql很容易完成sql server数据库的建表.删除表.更新表操作等等操作.接下来小编就给大家带来Heidisql ...

  • VS2008连接SQL Server数据库文件出错的解决方法

    有园子里的朋友问到一个问题:系统上安装的是vs2008+Sql 2005 developer(没有安装Sql server 2005 Express ) 用代码直接连SQL Server服务器没有问题 ...

  • unity3d怎么连接sql server数据库

    虽然在Unity3D中能够通过PlayerPrefs类来保存和读取数据,但是一旦数据量增大,仅仅通过代码的方式存取数据,这样的工作量是非常大的。那么如何通过使用Sql Server数据库来存取数据呢? ...

  • Excel如何连接SQL Server数据库

    Excel是现在十分常用的一款办公软件,有些新用户不知道该软件如何连接SQL Server数据库,接下来小编就给大家介绍一下具体的操作步骤.具体如下:1. 首先第一步根据下图所示,打开电脑中的Exce ...

  • 如何安装SQL Server数据库软件

    SQL Server是一个大型数据库软件,很多初学者对它比较陌生,不知道怎么安装它. 笔者与大家分享一下安装SQL Server数据库的技巧. 操作方法 01 从网上下载SQL Server2014安 ...