误区 #27:使用BACKUP ... WITH CHECKSUM可以替代DBCC CheckDB
错误
乍一看,由于BACKUP WITH CHECKSUM会检测所有分配出去的页的校验和的值,这个误区貌似是这么回事,但实际上并不是这么回事,原因如下:
由SQL Server 2000或是更早版本升上来的数据库page checksums必须开启,在开启后,并不是数据库中所有的页都会被叫上页校验和,当页损坏发生时,IO系统可不会区分损坏的页是有页校验和还是没有校验和的。所以使用BACKUP ... WITH CHECKSUM就有可能导致一些损坏页不被发现,造成的后果……
除此之外,还有一个问题是完整备份的时间间隔相对比较长,假如说一个月,而相对于DBCC CheckDB的最佳实践是一个礼拜,这导致WITH CHECKSUM不能替代CHECKDB。即使你每周都进行差异备份,但差异备份只会检测差异部分的页校验和。
最后一点,也是危害最大的一点,就是使用BACKUP WITH CHECKSUM选项不能发现内存中的页损坏。这是因为由于内存芯片或是WINDOWS进程导致内存中的页损坏,并且在这之后写回磁盘。这导致损坏页却有正常的校验和,只有使用DBCC CheckDB才能发现这类错误。
因此,说到底,你必须经常使用DBCC CHECKDB,如果对此你仍然心存疑问,请看我之前的一篇文章:CHECKDB From Every Angle: Consistency Checking Options for a VLDB。
扩展阅读:Search Engine Q&A #26: Myths around causing corruption
SQL Server误区30日谈 第27天 使用BACKUP WITH CHECKSUM可以替代DBCC CheckDB
2019-12-28 15:46MSSQL教程网 Sql Server
乍一看,由于BACKUP WITH CHECKSUM会检测所有分配出去的页的校验和的值,这个误区貌似是这么回事,但实际上并不是这么回事
延伸 · 阅读
- 2022-03-06C#连接SQL Server的实现方法
- 2022-03-05python读写文件with open的介绍
- 2022-03-04SQL Server2012无法连接到服务器的解决方法
- 2022-03-04python编程webpy框架模板之def with学习
- 2022-03-03SQL Server查询某个字段在哪些表中存在
- 2022-02-25Sql Server之数据类型详解
- Sql Server
sql2005 create file遇到操作系统错误5拒绝访问 错误1802
尝试打开或创建物理文件 'E:\Library.mdf' 时,CREATE FILE 遇到操作系统错误 5(拒绝访问。)。 ...
- Sql Server
防御SQL注入的方法总结
这篇文章主要讲解了防御SQL注入的方法,介绍了什么是注入,注入的原因是什么,以及如何防御,需要的朋友可以参考下 ...
- Sql Server
SQL SEVER数据库重建索引的方法
Sql Server查询缓慢的原因有很多,比如服务器资源不足、网络故障、查询语句不够优化,I/O问题等等,以及本文要说的数据库索引问题 ...
- Sql Server
字符串聚合函数(去除重复值)
提供字符串的替代聚合函数 ...
- Sql Server
如何正确的使用一条SQL删除重复数据
数据库中表存在重复数据,需要清理重复数据,清理后保留其中一条的情况是比较常见的需求,如何通过1条SQL准确的删除数据呢? 1. 创建表及测试数据 ...
- Sql Server
教你轻松恢复/修复SQL Server的MDF文件
下面将主要讨论一下后者的备份与恢复。本文假定您 能熟练使用SQL Server Enterprise Manager(SQL Server企业管理器)和SQL Server Quwey Analyser(SQL Server查询分析器) ...
- Sql Server
sql 时间函数 整理的比较全了
sql 时间函数,需要的朋友可以参考下。 ...
- Sql Server
SqlServer 2005 T-SQL Query 学习笔记(4)
作者他很喜欢建立数字辅助表(即是1-N的数字按顺序组成的表),关于如何建立这些辅助表,然后他给了一些例子,这些例子很有代表性。 ...