欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時間:2013年01月09日 19:21:31   投稿:mdxy-dxy  
在線索引操作會在操作開始時和操作結(jié)束時對資源上短暫的鎖。這有可能導(dǎo)致嚴重的阻塞問題

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

錯誤!

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

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

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

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

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

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

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

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

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

    grid.ai

相關(guān)文章

最新評論