SQL Server 数据库出现崩溃状况的补救

此文章主要介绍的是SQL Server 数据库出现崩溃的情况的恢复方案,在实际操作中可以说任何的数据库系统出现崩溃状况都是正常的,即便你使用了Clustered,双机热备……仍然无法完全根除系统中的单点故障,何况对于大部分用户来说,无法承受这样昂贵的硬件投资。

所以,在系统崩溃的时候,如何恢复原有的宝贵数据就成为一个极其重要的问题了。

在恢复的时候,最理想的情况就是你的数据文件和日志文件都完好无损了,这样只需要sp_attach_db,把数据文件附加到新的数据库上即可,或者在停机的时候把所有数据文件(一定要有master等)都copy到原有路径下也行,不过一般不推荐这样的做法,sp_attach_db比较好,虽然麻烦许多。

 

不幸的是,一般SQL Server 数据库崩溃都是由于存储子系统引起的,而这样的情况是几乎不可能有可用的日志用于恢复的。

 

首先,你可以试一下sp_attach_single_file_db,试着恢复一下你的数据文件,虽然能恢复的可能性不大,不过假如这个数据库刚好执行了一个checkpoint的话,还是有可能成功的。

 

我们可以试着重新建立一个Log,先把数据库设置为emergency mode,sysdatabases的status为32768 就表示SQL Server 数据库处于此状态。

 

不过系统表是不能随便改的,设置一下先Use MasterGosp_configure ‘allow updates’, 1reconfigure with overrideGo然后 update sysdatabases set status = 32768 where name = ” 现在,祈求满天神佛的保佑吧,重新建立一个log文件。成功的机会还是相当大的,系统一般都会认可你新建立的日志。如果没有报告什么错误,现在就可以松一口气了。

 

虽然数据是恢复了,可是别以为事情就算完成了,正在进行的事务肯定是丢失了,原来的数据也可能受到一些损坏:

 

先把SQL Server 重新启动一下,然后检查你的数据库吧;

 

先设置成单用户模式,然后做dbcc sp_dboption ”, ‘single user’, ‘true’DBCC CHECKDB(”);

 

如果没有什么大问题就可以把SQL Server 数据库状态改回去了,记得别忘了把系统表的修改选项关掉。update sysdatabases set status = 28 where name = ” ,当然你的数据库状态可能不是这个,自己改为合适的值吧。也可以用:

 

 

  1. sp_resetstatusgosp_configure 'allow updates', 0reconfigure with overrideGo 

checkdb的时候可能报告有一些错误,这些错误的数据你可能就只好丢弃了;checkdb有几种修复选项,自己看着用吧,不过***你可能还是得REPAIR_ALLOW_DATA_LOSS,完成所有修复;chekcdb并不能完成所有的修复,我们需要更进一步的修复,用DBCC CHECKTABLE对每一个表做检查吧。

表的列表可以用sysobjects里面得到,把OBJECTPROPERTY是IsTable的全部找出来检查一下吧,这样能够基本上解决问题了,如果还报告错误,试着把数据select into到另一张表检查一下。

 

这些都做完了之后,把所有索引、视图、存储过程、触发器等重新建立一下。可以从DBCC DBREINDEX得到帮助。

 

以上的相关内容就是对SQL Server 数据库崩溃后的恢复之法的介绍,望你能有所收获。

上述的相关内容就是对SQL Server 数据库崩溃后的恢复之法的描述,希望会给你带来一些帮助在此方面。

【编辑推荐】

  1. MS-SQL server数据库开发中的技巧
  2. SQL Server里调用COM组件的操作流程
  3. SQL Server安全规划的阐述
  4. 配置Tomcat+SQL Server2000连接池流程
  5. SQL Server Model增加一些变化,很简单!

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/301374.html<

(0)
运维的头像运维
上一篇2025-05-24 07:31
下一篇 2025-05-24 07:33

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注