主頁 > 知識庫 > SQL Server誤區(qū)30日談 第8天 有關對索引進行在線操作的誤區(qū)

SQL Server誤區(qū)30日談 第8天 有關對索引進行在線操作的誤區(qū)

熱門標簽:智能語音外呼系統(tǒng)哪個牌子好 溫州語音外呼系統(tǒng)代理 北京辦理400電話多少 西安青牛防封電銷卡 重慶防封電銷機器人供應商 400電話申請需要開戶費嗎 威海智能語音外呼系統(tǒng) 南京電銷外呼系統(tǒng)運營商 山西語音外呼系統(tǒng)價格

誤區(qū) #8: 在線索引操作不會使得相關的索引加鎖

錯誤!

    在線索引操作并不是想象的那么美好。

    在線索引操作會在操作開始時和操作結束時對資源上短暫的鎖。這有可能導致嚴重的阻塞問題。

    在線索引操作開始時,會在被整理的資源上加一個共享的表鎖,這個表鎖在會在新的索引創(chuàng)建時、老索引進行版本掃描時一直持續(xù)。

    但問題是,這個S鎖會和表上的其它鎖排成鎖隊列。這也就是意味著和S鎖不兼容的其它鎖在表上存在S鎖或是表上的鎖隊列存在中包含S鎖時,這類和S鎖不兼容的鎖操作也需要等待。這也意味著各種更新操作會被阻塞。同樣,如果表上存在X鎖或是IX鎖時,S鎖請求也會被阻塞。

    上述步驟完成后,S鎖會被去掉,但你可以發(fā)現這已經對數據更新產生了影響。這期間還會造成所有等待的更新操作的執(zhí)行計劃被重新編譯

    在線索引整理在開始需要加鎖的部分完成后,剩下的大部分時間是不需要任何鎖的。(這個大部分指的是整個在線索引整理的大部分時間)

    當在線索引操作完成后,新建立的索引和老的索引上面都需要加一個構架修改鎖(SCH_M鎖)來完成最終操作。這個鎖可以想象成一個更強的表級排它鎖。這個鎖存在期間不允許對表做任何操作,針對表的執(zhí)行計劃也不能重編譯。

    在線索引操作最終階段的阻塞問題和在線索引操作開始時由S鎖造成的阻塞問題非常類似-在SCH_M鎖持續(xù)或者等待被授予期間,不允許對表進行任何操作。反之,表中存在任何讀寫操作時,SCH_M鎖也不能被授予。

    在最終階段的SCH_M鎖持續(xù)期間,舊的索引會被執(zhí)行延遲DROP操作,元數據所指向的分配結構指向新的索引(所以index id不變),表的版本被更新,恭喜,現在開始你已經擁有了一個全新的索引。

    如你所見,在線索引操作的開始和結束階段潛在存在著巨大的阻塞問題。所以技術上對在線索引操作應該稱為“大部分時間在線索引操作”,但這種叫法可不會受到市場的歡迎。如果你想對在線索引操作了解更多,請閱讀白皮書:Online Indexing Operations in SQL Server 2005。

 

    譯者注:汪洋有一篇關于在線索引操作非常詳細的文章,有興趣的同學可以閱讀: 聯(lián)機索引的工作方式 ,下面我摘抄他文章中的一個圖片來讓在線索引操作的步驟更加清晰。

   

您可能感興趣的文章:
  • SQL Server誤區(qū)30日談 第29天 有關堆碎片的誤區(qū)
  • SQL Server誤區(qū)30日談 第28天 有關大容量事務日志恢復模式的誤區(qū)
  • SQL Server誤區(qū)30日談 第27天 使用BACKUP WITH CHECKSUM可以替代DBCC CheckDB
  • 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天 數據損壞可以通過重啟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天 數據的損壞和修復
  • 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的文件數和需要和CPU數目保持一致
  • SQL Server誤區(qū)30日談 第11天 鏡像在檢測到故障后瞬間就能故障轉移
  • SQL Server誤區(qū)30日談 第10天 數據庫鏡像在故障發(fā)生后 馬上就能發(fā)現
  • SQL Server誤區(qū)30日談 第9天 數據庫文件收縮不會影響性能
  • 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ū)

標簽:貸款群呼 中衛(wèi) 黃山 新余 濟寧 金昌 河源 宜春

巨人網絡通訊聲明:本文標題《SQL Server誤區(qū)30日談 第8天 有關對索引進行在線操作的誤區(qū)》,本文關鍵詞  SQL,Server,誤區(qū),30日談,第,;如發(fā)現本文內容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內容系統(tǒng)采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《SQL Server誤區(qū)30日談 第8天 有關對索引進行在線操作的誤區(qū)》相關的同類信息!
  • 本頁收集關于SQL Server誤區(qū)30日談 第8天 有關對索引進行在線操作的誤區(qū)的相關信息資訊供網民參考!
  • 推薦文章