SQL Server誤區(qū)30日談 第8天 有關(guān)對(duì)索引進(jìn)行在線(xiàn)操作的誤區(qū)
誤區(qū) #8: 在線(xiàn)索引操作不會(huì)使得相關(guān)的索引加鎖
錯(cuò)誤!
在線(xiàn)索引操作并不是想象的那么美好。
在線(xiàn)索引操作會(huì)在操作開(kāi)始時(shí)和操作結(jié)束時(shí)對(duì)資源上短暫的鎖。這有可能導(dǎo)致嚴(yán)重的阻塞問(wèn)題。
在線(xiàn)索引操作開(kāi)始時(shí),會(huì)在被整理的資源上加一個(gè)共享的表鎖,這個(gè)表鎖在會(huì)在新的索引創(chuàng)建時(shí)、老索引進(jìn)行版本掃描時(shí)一直持續(xù)。
但問(wèn)題是,這個(gè)S鎖會(huì)和表上的其它鎖排成鎖隊(duì)列。這也就是意味著和S鎖不兼容的其它鎖在表上存在S鎖或是表上的鎖隊(duì)列存在中包含S鎖時(shí),這類(lèi)和S鎖不兼容的鎖操作也需要等待。這也意味著各種更新操作會(huì)被阻塞。同樣,如果表上存在X鎖或是IX鎖時(shí),S鎖請(qǐng)求也會(huì)被阻塞。
上述步驟完成后,S鎖會(huì)被去掉,但你可以發(fā)現(xiàn)這已經(jīng)對(duì)數(shù)據(jù)更新產(chǎn)生了影響。這期間還會(huì)造成所有等待的更新操作的執(zhí)行計(jì)劃被重新編譯
在線(xiàn)索引整理在開(kāi)始需要加鎖的部分完成后,剩下的大部分時(shí)間是不需要任何鎖的。(這個(gè)大部分指的是整個(gè)在線(xiàn)索引整理的大部分時(shí)間)
當(dāng)在線(xiàn)索引操作完成后,新建立的索引和老的索引上面都需要加一個(gè)構(gòu)架修改鎖(SCH_M鎖)來(lái)完成最終操作。這個(gè)鎖可以想象成一個(gè)更強(qiáng)的表級(jí)排它鎖。這個(gè)鎖存在期間不允許對(duì)表做任何操作,針對(duì)表的執(zhí)行計(jì)劃也不能重編譯。
在線(xiàn)索引操作最終階段的阻塞問(wèn)題和在線(xiàn)索引操作開(kāi)始時(shí)由S鎖造成的阻塞問(wèn)題非常類(lèi)似-在SCH_M鎖持續(xù)或者等待被授予期間,不允許對(duì)表進(jìn)行任何操作。反之,表中存在任何讀寫(xiě)操作時(shí),SCH_M鎖也不能被授予。
在最終階段的SCH_M鎖持續(xù)期間,舊的索引會(huì)被執(zhí)行延遲DROP操作,元數(shù)據(jù)所指向的分配結(jié)構(gòu)指向新的索引(所以index id不變),表的版本被更新,恭喜,現(xiàn)在開(kāi)始你已經(jīng)擁有了一個(gè)全新的索引。
相關(guān)文章
SQL查詢(xún)語(yǔ)句求出用戶(hù)的連續(xù)登陸天數(shù)
這篇文章主要是SQl語(yǔ)句的練習(xí),本文教大家如何用SQL查詢(xún)語(yǔ)句求出用戶(hù)的連續(xù)登陸天數(shù),有需要的朋友可以借鑒參考下,希望能夠有所幫助2021-10-10sqlserver 查詢(xún)數(shù)據(jù)庫(kù)大小的方法
總部要求每一個(gè)月,獲取一次ERP數(shù)據(jù)庫(kù)增長(zhǎng)大小。我收到的樣版是一張截圖,是直接查看數(shù)據(jù)庫(kù)文件大小2012-08-08sql server動(dòng)態(tài)存儲(chǔ)過(guò)程按日期保存數(shù)據(jù)示例
,在sql server存儲(chǔ)過(guò)程中進(jìn)行日期計(jì)算,按日期建表效率最高,下面就公司項(xiàng)目的部分動(dòng)態(tài)存儲(chǔ)過(guò)程粘貼出來(lái)2014-08-08bak文件怎么打開(kāi) 2000w數(shù)據(jù)怎么打開(kāi)?
這篇文章主要介紹了sqlserver數(shù)據(jù)庫(kù)bak文件如何恢復(fù)打開(kāi)的方法,需要的朋友可以參考下2014-02-02SQL Server 2012無(wú)法連接到WMI提供程序(Cannot connect to WMI provider)解
這篇文章主要介紹了SQL Server 2012無(wú)法連接到WMI提供程序(Cannot connect to WMI provider)解決方案,需要的朋友可以參考下2014-07-07SQL Server 2016里的sys.dm_exec_input_buffer的問(wèn)題
這篇文章主要介紹了SQL Server 2016里的sys.dm_exec_input_buffer的相關(guān)資料,需要的朋友可以參考下2016-04-04SQL Server SQL高級(jí)查詢(xún)語(yǔ)句小結(jié)
高級(jí)查詢(xún)?cè)跀?shù)據(jù)庫(kù)中用得是最頻繁的,也是應(yīng)用最廣泛的。 學(xué)習(xí)sqlserver的朋友可以參考下。2011-07-07