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

时间:2024-01-23 01:53:48 

误区 #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子系统恢复。我只碰见过三四次这类情况。


    不管怎么说,你起码要做到有对应的备份策略或是容易系统进行恢复和故障转移。重启可不是一个解决方案,这只会浪费时间。

标签:数据损坏
0
投稿

猜你喜欢

  • Anaconda最新版2023安装教程Spyder安装教程图文详解

    2021-12-24 00:29:56
  • ASP分页显示Recordset数据

    2008-11-07 15:43:00
  • Python3使用TCP编写一个简易的文件下载器功能

    2021-02-20 09:58:07
  • php中替换字符串函数strtr()和str_repalce()的用法与区别

    2023-11-17 06:12:53
  • 解析mysql修改为utf8后仍然有乱码的问题

    2024-01-14 14:36:09
  • Python中的套接字编程是什么?

    2021-02-28 12:46:01
  • PHP header()函数常用方法总结

    2023-09-06 16:51:50
  • vscode调试container中的程序的方法步骤

    2022-03-06 14:20:25
  • ORACLE数据库事务隔离级别介绍

    2012-10-07 10:43:36
  • 对Matlab中共轭、转置和共轭装置的区别说明

    2023-12-23 00:47:22
  • MySQL UNION操作符基础知识点

    2024-01-21 10:24:31
  • Python基于Tkinter开发一个爬取B站直播弹幕的工具

    2023-06-21 21:53:12
  • 提供效率的几个ASP编程技巧

    2010-05-03 11:11:00
  • 10个杀手级应用的Python自动化脚本

    2023-10-06 14:01:53
  • MySQL基于GTID主从搭建

    2024-01-23 18:17:56
  • 如何用C代码给Python写扩展库(Cython)

    2023-06-08 17:06:32
  • jdbc连接sqlserver数据库示例

    2024-01-17 12:56:16
  • python关于变量名的基础知识点

    2023-07-27 14:21:43
  • 简单介绍Python中的floor()方法

    2023-06-08 03:36:21
  • SqlServer中tempdb的日志机制原理解析及示例分享

    2024-01-15 20:31:38
  • asp之家 网络编程 m.aspxhome.com