SQL Server誤區(qū)30日談 第27天 使用BACKUP WITH CHECKSUM可以替代DBCC CheckDB
更新時間:2013年01月09日 22:08:54 作者:
乍一看,由于BACKUP WITH CHECKSUM會檢測所有分配出去的頁的校驗和的值,這個誤區(qū)貌似是這么回事,但實際上并不是這么回事
誤區(qū) #27:使用BACKUP ... WITH CHECKSUM可以替代DBCC CheckDB
錯誤
乍一看,由于BACKUP WITH CHECKSUM會檢測所有分配出去的頁的校驗和的值,這個誤區(qū)貌似是這么回事,但實際上并不是這么回事,原因如下:
由SQL Server 2000或是更早版本升上來的數(shù)據(jù)庫page checksums必須開啟,在開啟后,并不是數(shù)據(jù)庫中所有的頁都會被叫上頁校驗和,當頁損壞發(fā)生時,IO系統(tǒng)可不會區(qū)分損壞的頁是有頁校驗和還是沒有校驗和的。所以使用BACKUP ... WITH CHECKSUM就有可能導致一些損壞頁不被發(fā)現(xiàn),造成的后果……
除此之外,還有一個問題是完整備份的時間間隔相對比較長,假如說一個月,而相對于DBCC CheckDB的最佳實踐是一個禮拜,這導致WITH CHECKSUM不能替代CHECKDB。即使你每周都進行差異備份,但差異備份只會檢測差異部分的頁校驗和。
最后一點,也是危害最大的一點,就是使用BACKUP WITH CHECKSUM選項不能發(fā)現(xiàn)內存中的頁損壞。這是因為由于內存芯片或是WINDOWS進程導致內存中的頁損壞,并且在這之后寫回磁盤。這導致?lián)p壞頁卻有正常的校驗和,只有使用DBCC CheckDB才能發(fā)現(xiàn)這類錯誤。
因此,說到底,你必須經(jīng)常使用DBCC CHECKDB,如果對此你仍然心存疑問,請看我之前的一篇文章:CHECKDB From Every Angle: Consistency Checking Options for a VLDB。
擴展閱讀:Search Engine Q&A #26: Myths around causing corruption
錯誤
乍一看,由于BACKUP WITH CHECKSUM會檢測所有分配出去的頁的校驗和的值,這個誤區(qū)貌似是這么回事,但實際上并不是這么回事,原因如下:
由SQL Server 2000或是更早版本升上來的數(shù)據(jù)庫page checksums必須開啟,在開啟后,并不是數(shù)據(jù)庫中所有的頁都會被叫上頁校驗和,當頁損壞發(fā)生時,IO系統(tǒng)可不會區(qū)分損壞的頁是有頁校驗和還是沒有校驗和的。所以使用BACKUP ... WITH CHECKSUM就有可能導致一些損壞頁不被發(fā)現(xiàn),造成的后果……
除此之外,還有一個問題是完整備份的時間間隔相對比較長,假如說一個月,而相對于DBCC CheckDB的最佳實踐是一個禮拜,這導致WITH CHECKSUM不能替代CHECKDB。即使你每周都進行差異備份,但差異備份只會檢測差異部分的頁校驗和。
最后一點,也是危害最大的一點,就是使用BACKUP WITH CHECKSUM選項不能發(fā)現(xiàn)內存中的頁損壞。這是因為由于內存芯片或是WINDOWS進程導致內存中的頁損壞,并且在這之后寫回磁盤。這導致?lián)p壞頁卻有正常的校驗和,只有使用DBCC CheckDB才能發(fā)現(xiàn)這類錯誤。
因此,說到底,你必須經(jīng)常使用DBCC CHECKDB,如果對此你仍然心存疑問,請看我之前的一篇文章:CHECKDB From Every Angle: Consistency Checking Options for a VLDB。
擴展閱讀:Search Engine Q&A #26: Myths around causing corruption
您可能感興趣的文章:
- SQL Server誤區(qū)30日談 第29天 有關堆碎片的誤區(qū)
- SQL Server誤區(qū)30日談 第28天 有關大容量事務日志恢復模式的誤區(qū)
- SQL Server誤區(qū)30日談 第26天 SQL Server中存在真正的“事務嵌套”
- SQL Server誤區(qū)30日談 第25天 有關填充因子的誤區(qū)
- SQL Server誤區(qū)30日談 第24天 26個有關還原(Restore)的誤區(qū)
- SQL Server誤區(qū)30日談 第23天 有關鎖升級的誤區(qū)
- SQL Server誤區(qū)30日談 第22天 資源調控器可以調控IO
- SQL Server誤區(qū)30日談 第21天 數(shù)據(jù)損壞可以通過重啟SQL Server來修復
- SQL Server誤區(qū)30日談 第20天 破壞日志備份鏈之后,需要一個完整備份來重新開始日志鏈
- SQL Server誤區(qū)30日談 第19天 Truncate表的操作不會被記錄到日志
- SQL Server誤區(qū)30日談 第18天 有關FileStream的存儲,垃圾回收以及其它
- SQL Server誤區(qū)30日談 第17天 有關頁校驗和的誤區(qū)
- SQL Server誤區(qū)30日談 第16天 數(shù)據(jù)的損壞和修復
- SQL Server誤區(qū)30日談 第15天 CheckPoint只會將已提交的事務寫入磁盤
- SQL Server誤區(qū)30日談 第14天 清除日志后會將相關的LSN填零初始化
- SQL Server誤區(qū)30日談 第13天 在SQL Server 2000兼容模式下不能使用DMV
- SQL Server誤區(qū)30日談 第12天 TempDB的文件數(shù)和需要和CPU數(shù)目保持一致
- SQL Server誤區(qū)30日談 第11天 鏡像在檢測到故障后瞬間就能故障轉移
- SQL Server誤區(qū)30日談 第10天 數(shù)據(jù)庫鏡像在故障發(fā)生后 馬上就能發(fā)現(xiàn)
- SQL Server誤區(qū)30日談 第9天 數(shù)據(jù)庫文件收縮不會影響性能
- SQL Server誤區(qū)30日談 第8天 有關對索引進行在線操作的誤區(qū)
- SQL Server誤區(qū)30日談 第7天 一個實例多個鏡像和日志傳送延遲
- SQL Server誤區(qū)30日談 第6天 有關NULL位圖的三個誤區(qū)
- SQL Server誤區(qū)30日談 第5天 AWE在64位SQL SERVER中必須開啟
- SQL Server誤區(qū)30日談 第4天 DDL觸發(fā)器就是INSTEAD OF觸發(fā)器
- SQL Server誤區(qū)30日談 第3天 即時文件初始化特性可以在SQL Server中開啟和關閉
- SQL Server誤區(qū)30日談 第2天 DBCC CHECKDB會導致阻塞
- SQL Server誤區(qū)30日談 第1天 正在運行的事務在服務器故障轉移后繼續(xù)執(zhí)行
- SQL Server誤區(qū)30日談 第30天 有關備份的30個誤區(qū)
相關文章
SQL Server 數(shù)據(jù)庫管理常用的SQL和T-SQL語句
SQL Server 數(shù)據(jù)庫管理常用的SQL和T-SQL語句...2007-03-03SQL Server中聚合歷史備份信息對比數(shù)據(jù)庫增長的方法
這篇文章主要介紹了SQL Server中聚合歷史備份信息對比數(shù)據(jù)庫增長的方法,需要的朋友可以參考下2014-09-09通過SQLSERVER重啟SQLSERVER服務和計算機的方法
為了實現(xiàn)遠程重新啟動,從而想到了用SQL語句命令實現(xiàn)這個功能,但是具體的命令格式給忘記了,找了點資料,把方法寫在下面2010-09-09