数据库 
首页 > 数据库 > 浏览文章

SQL Server误区30日谈 第21天 数据损坏可以通过重启SQL Server来修复

(编辑:jimmy 日期: 2024/11/14 浏览:3 次 )
误区 #21:数据库损坏可以通过重启SQL Server或是Windows,或是附加和分离数据库解决

错误

SQL Server中没有任何一项操作可以修复数据损坏。损坏的页当然需要通过某种机制进行修复或是恢复-但绝不是通过重启动SQL Server,Windows亦或是分离附加数据库。

而实际上,如果你的数据库的损坏程度无法进行Crash Recovery的话(质疑状态),那么分离附加数据库将会是你做的最糟糕的决定。这个原理是由于附加数据库中包含Crash Recovery步骤,如果Crash Recovery失败的话,那么附加也会失败。所以下面的技巧才是你所需要的:TechEd Demo: Creating, detaching, re-attaching, and fixing a suspect database。记住,永远不要分离损坏的数据库。
下面这类错误才是有可能通过重启解决:

  • 如果在内存中的页损坏,但在磁盘上的页完好时,重启能够解决损坏问题
  • 如果损坏发生了,但是重启过程中的某个步骤导致这个页不再被分配,则貌似损坏通过重启解决了,这个问题我之前已经有一篇博文进行阐述了:Misconceptions around corruptions: can they disappear?
  • 如果IO子系统也重启,之前SQL Server对IO的需求被IO子系统“卡”住,则重启貌似能解决问题,但实际上这并不是修复损坏,而只是让出问题的IO子系统恢复。我只碰见过三四次这类情况。

    不管怎么说,你起码要做到有对应的备份策略或是容易系统进行恢复和故障转移。重启可不是一个解决方案,这只会浪费时间。
上一篇:SQL Server误区30日谈 第12天 TempDB的文件数和需要和CPU数目保持一致
下一篇:SQL Server误区30日谈 第11天 镜像在检测到故障后瞬间就能故障转移
一句话新闻
高通与谷歌联手!首款骁龙PC优化Chrome浏览器发布
高通和谷歌日前宣布,推出首次面向搭载骁龙的Windows PC的优化版Chrome浏览器。
在对骁龙X Elite参考设计的初步测试中,全新的Chrome浏览器在Speedometer 2.1基准测试中实现了显著的性能提升。
预计在2024年年中之前,搭载骁龙X Elite计算平台的PC将面世。该浏览器的提前问世,有助于骁龙PC问世就获得满血表现。
谷歌高级副总裁Hiroshi Lockheimer表示,此次与高通的合作将有助于确保Chrome用户在当前ARM兼容的PC上获得最佳的浏览体验。