SQL Server誤區(qū)30日談 第27天 使用BACKUP WITH CHECKSUM可以替代DBCC CheckDB
更新時(shí)間:2013年01月09日 22:08:54 作者:
乍一看,由于BACKUP WITH CHECKSUM會(huì)檢測(cè)所有分配出去的頁(yè)的校驗(yàn)和的值,這個(gè)誤區(qū)貌似是這么回事,但實(shí)際上并不是這么回事
誤區(qū) #27:使用BACKUP ... WITH CHECKSUM可以替代DBCC CheckDB
錯(cuò)誤
乍一看,由于BACKUP WITH CHECKSUM會(huì)檢測(cè)所有分配出去的頁(yè)的校驗(yàn)和的值,這個(gè)誤區(qū)貌似是這么回事,但實(shí)際上并不是這么回事,原因如下:
由SQL Server 2000或是更早版本升上來(lái)的數(shù)據(jù)庫(kù)page checksums必須開(kāi)啟,在開(kāi)啟后,并不是數(shù)據(jù)庫(kù)中所有的頁(yè)都會(huì)被叫上頁(yè)校驗(yàn)和,當(dāng)頁(yè)損壞發(fā)生時(shí),IO系統(tǒng)可不會(huì)區(qū)分損壞的頁(yè)是有頁(yè)校驗(yàn)和還是沒(méi)有校驗(yàn)和的。所以使用BACKUP ... WITH CHECKSUM就有可能導(dǎo)致一些損壞頁(yè)不被發(fā)現(xiàn),造成的后果……
除此之外,還有一個(gè)問(wèn)題是完整備份的時(shí)間間隔相對(duì)比較長(zhǎng),假如說(shuō)一個(gè)月,而相對(duì)于DBCC CheckDB的最佳實(shí)踐是一個(gè)禮拜,這導(dǎo)致WITH CHECKSUM不能替代CHECKDB。即使你每周都進(jìn)行差異備份,但差異備份只會(huì)檢測(cè)差異部分的頁(yè)校驗(yàn)和。
最后一點(diǎn),也是危害最大的一點(diǎn),就是使用BACKUP WITH CHECKSUM選項(xiàng)不能發(fā)現(xiàn)內(nèi)存中的頁(yè)損壞。這是因?yàn)橛捎趦?nèi)存芯片或是WINDOWS進(jìn)程導(dǎo)致內(nèi)存中的頁(yè)損壞,并且在這之后寫(xiě)回磁盤(pán)。這導(dǎo)致?lián)p壞頁(yè)卻有正常的校驗(yàn)和,只有使用DBCC CheckDB才能發(fā)現(xiàn)這類錯(cuò)誤。
因此,說(shuō)到底,你必須經(jīng)常使用DBCC CHECKDB,如果對(duì)此你仍然心存疑問(wèn),請(qǐng)看我之前的一篇文章:CHECKDB From Every Angle: Consistency Checking Options for a VLDB。
擴(kuò)展閱讀:Search Engine Q&A #26: Myths around causing corruption
錯(cuò)誤
乍一看,由于BACKUP WITH CHECKSUM會(huì)檢測(cè)所有分配出去的頁(yè)的校驗(yàn)和的值,這個(gè)誤區(qū)貌似是這么回事,但實(shí)際上并不是這么回事,原因如下:
由SQL Server 2000或是更早版本升上來(lái)的數(shù)據(jù)庫(kù)page checksums必須開(kāi)啟,在開(kāi)啟后,并不是數(shù)據(jù)庫(kù)中所有的頁(yè)都會(huì)被叫上頁(yè)校驗(yàn)和,當(dāng)頁(yè)損壞發(fā)生時(shí),IO系統(tǒng)可不會(huì)區(qū)分損壞的頁(yè)是有頁(yè)校驗(yàn)和還是沒(méi)有校驗(yàn)和的。所以使用BACKUP ... WITH CHECKSUM就有可能導(dǎo)致一些損壞頁(yè)不被發(fā)現(xiàn),造成的后果……
除此之外,還有一個(gè)問(wèn)題是完整備份的時(shí)間間隔相對(duì)比較長(zhǎng),假如說(shuō)一個(gè)月,而相對(duì)于DBCC CheckDB的最佳實(shí)踐是一個(gè)禮拜,這導(dǎo)致WITH CHECKSUM不能替代CHECKDB。即使你每周都進(jìn)行差異備份,但差異備份只會(huì)檢測(cè)差異部分的頁(yè)校驗(yàn)和。
最后一點(diǎn),也是危害最大的一點(diǎn),就是使用BACKUP WITH CHECKSUM選項(xiàng)不能發(fā)現(xiàn)內(nèi)存中的頁(yè)損壞。這是因?yàn)橛捎趦?nèi)存芯片或是WINDOWS進(jìn)程導(dǎo)致內(nèi)存中的頁(yè)損壞,并且在這之后寫(xiě)回磁盤(pán)。這導(dǎo)致?lián)p壞頁(yè)卻有正常的校驗(yàn)和,只有使用DBCC CheckDB才能發(fā)現(xiàn)這類錯(cuò)誤。
因此,說(shuō)到底,你必須經(jīng)常使用DBCC CHECKDB,如果對(duì)此你仍然心存疑問(wèn),請(qǐng)看我之前的一篇文章:CHECKDB From Every Angle: Consistency Checking Options for a VLDB。
擴(kuò)展閱讀:Search Engine Q&A #26: Myths around causing corruption
您可能感興趣的文章:
- SQL Server誤區(qū)30日談 第29天 有關(guān)堆碎片的誤區(qū)
- SQL Server誤區(qū)30日談 第28天 有關(guān)大容量事務(wù)日志恢復(fù)模式的誤區(qū)
- SQL Server誤區(qū)30日談 第26天 SQL Server中存在真正的“事務(wù)嵌套”
- SQL Server誤區(qū)30日談 第25天 有關(guān)填充因子的誤區(qū)
- SQL?Server誤區(qū)30日談?第24天?26個(gè)有關(guān)還原(Restore)的誤區(qū)
- SQL Server誤區(qū)30日談 第23天 有關(guān)鎖升級(jí)的誤區(qū)
- SQL Server誤區(qū)30日談 第22天 資源調(diào)控器可以調(diào)控IO
- SQL Server誤區(qū)30日談 第21天 數(shù)據(jù)損壞可以通過(guò)重啟SQL Server來(lái)修復(fù)
- SQL Server誤區(qū)30日談 第20天 破壞日志備份鏈之后,需要一個(gè)完整備份來(lái)重新開(kāi)始日志鏈
- SQL Server誤區(qū)30日談 第19天 Truncate表的操作不會(huì)被記錄到日志
- SQL Server誤區(qū)30日談 第18天 有關(guān)FileStream的存儲(chǔ),垃圾回收以及其它
- SQL Server誤區(qū)30日談 第17天 有關(guān)頁(yè)校驗(yàn)和的誤區(qū)
- SQL Server誤區(qū)30日談 第16天 數(shù)據(jù)的損壞和修復(fù)
- SQL Server誤區(qū)30日談 第15天 CheckPoint只會(huì)將已提交的事務(wù)寫(xiě)入磁盤(pán)
- SQL Server誤區(qū)30日談 第14天 清除日志后會(huì)將相關(guān)的LSN填零初始化
- SQL Server誤區(qū)30日談 第13天 在SQL Server 2000兼容模式下不能使用DMV
- SQL Server誤區(qū)30日談 第12天 TempDB的文件數(shù)和需要和CPU數(shù)目保持一致
- SQL Server誤區(qū)30日談 第11天 鏡像在檢測(cè)到故障后瞬間就能故障轉(zhuǎn)移
- SQL Server誤區(qū)30日談 第10天 數(shù)據(jù)庫(kù)鏡像在故障發(fā)生后 馬上就能發(fā)現(xiàn)
- SQL Server誤區(qū)30日談 第9天 數(shù)據(jù)庫(kù)文件收縮不會(huì)影響性能
- SQL Server誤區(qū)30日談 第8天 有關(guān)對(duì)索引進(jìn)行在線操作的誤區(qū)
- SQL Server誤區(qū)30日談 第7天 一個(gè)實(shí)例多個(gè)鏡像和日志傳送延遲
- SQL Server誤區(qū)30日談 第6天 有關(guān)NULL位圖的三個(gè)誤區(qū)
- SQL Server誤區(qū)30日談 第5天 AWE在64位SQL SERVER中必須開(kāi)啟
- SQL Server誤區(qū)30日談 第4天 DDL觸發(fā)器就是INSTEAD OF觸發(fā)器
- SQL Server誤區(qū)30日談 第3天 即時(shí)文件初始化特性可以在SQL Server中開(kāi)啟和關(guān)閉
- SQL Server誤區(qū)30日談 第2天 DBCC CHECKDB會(huì)導(dǎo)致阻塞
- SQL Server誤區(qū)30日談 第1天 正在運(yùn)行的事務(wù)在服務(wù)器故障轉(zhuǎn)移后繼續(xù)執(zhí)行
- SQL Server誤區(qū)30日談 第30天 有關(guān)備份的30個(gè)誤區(qū)
相關(guān)文章
用sql實(shí)現(xiàn)18位身份證校驗(yàn)代碼分享 身份證校驗(yàn)位計(jì)算
這篇文章主要介紹了用SQL寫(xiě)的18位身份證校驗(yàn)代碼,大家參考使用吧2014-01-01
SQL SERVER 2014 安裝圖解教程(含SQL SERVER 2014下載)
這篇文章主要介紹了SQL SERVER 2014 安裝圖解教程(含SQL SERVER 2014下載),需要的朋友可以參考下2015-10-10
SQL Server 分頁(yè)編號(hào)的另一種方式【推薦】
這篇文章主要介紹了SQL Server 分頁(yè)編號(hào)的另一種方式,需要的朋友可以參考下2018-06-06
MySQL多表聯(lián)查給null賦值的實(shí)現(xiàn)
NULL值表示缺失或未知的數(shù)據(jù),本文主要介紹了MySQL多表聯(lián)查給null賦值的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2024-08-08
SQLSERVER 語(yǔ)句交錯(cuò)引發(fā)的死鎖問(wèn)題案例詳解
這篇文章主要介紹了SQLSERVER 語(yǔ)句交錯(cuò)引發(fā)的死鎖研究,要解決死鎖問(wèn)題,個(gè)人感覺(jué)需要非常熟知各種隔離級(jí)別,尤其是 可提交讀 模式下的 CURD 加解鎖過(guò)程,這一篇我們就來(lái)好好聊一聊2023-02-02
sql server編寫(xiě)archive通用模板腳本實(shí)現(xiàn)自動(dòng)分批刪除數(shù)據(jù)
這篇文章主要介紹了sql server編寫(xiě)archive通用模板腳本實(shí)現(xiàn)自動(dòng)分批刪除數(shù)據(jù),需要的朋友可以參考下2019-10-10
SQL處理多級(jí)分類,查詢結(jié)果呈樹(shù)形結(jié)構(gòu)
對(duì)于多級(jí)分類常規(guī)的處理方法,很多程序員可能是用程序先讀取一級(jí)分類記錄,然后通過(guò)一級(jí)分類循環(huán)讀取下面的子分類2012-08-08

