麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁(yè) > 數(shù)據(jù)庫(kù) > SQL Server > 正文

SQL Server中的SELECT會(huì)阻塞SELECT嗎

2024-08-31 01:05:29
字體:
供稿:網(wǎng)友

前言

在SQL Server中,我們知道一個(gè)SELECT語(yǔ)句執(zhí)行過程中只會(huì)申請(qǐng)一些意向共享鎖(IS) 與共享鎖(S), 例如我使用SQL Profile跟蹤會(huì)話86執(zhí)行SELECT * FROM dbo.TEST WHERE OBJECT_ID =1 這個(gè)查詢語(yǔ)句,其申請(qǐng)、釋放的鎖資源的過程如下所示:

SQLServer,SELECT,阻塞

而且從最常見的鎖模式的兼容性表,我們可以看到IS鎖與S鎖都是兼容的,也就是說SELECT查詢是不會(huì)阻塞SELECT查詢的。

 

 

現(xiàn)有的授權(quán)模式

請(qǐng)求的模式

IS

S

U

IX

SIX

X

意向共享 (IS)

共享 (S)

更新 (U)

意向排他 (IX)

意向排他共享(SIX)

排他 (X)

 

但是在某些特殊場(chǎng)景。你會(huì)看到SELECT語(yǔ)句居然“阻塞”SELECT操作,那么SQL Server中SELECT會(huì)真的阻塞SELECT操作嗎?我們先構(gòu)造測(cè)試的案例場(chǎng)景,那么先準(zhǔn)備測(cè)試數(shù)據(jù)吧

CREATE TABLE TEST (OBJECT_ID INT, NAME VARCHAR(8)); CREATE INDEX PK_TEST ON TEST(OBJECT_ID)   DECLARE @Index INT =0; WHILE @Index < 20BEGIN INSERT INTO TEST SELECT @Index, 'kerry';  SET @Index = @Index +1;END

在會(huì)話窗口A中,執(zhí)行下面SQL語(yǔ)句,模擬一個(gè)UPDATE語(yǔ)句正在執(zhí)行

BEGIN TRANSACTION  UPDATE dbo.TEST SET NAME='Kerry' WHERE OBJECT_ID=1; --ROLLBACK;

會(huì)話窗口B中,執(zhí)行下面的SQL語(yǔ)句

SELECT * FROM dbo.TEST WHERE OBJECT_ID=1

會(huì)話窗口C中,執(zhí)行下面的SQL語(yǔ)句

SELECT * FROM dbo.TEST WHERE OBJECT_ID=1

我實(shí)驗(yàn)的場(chǎng)景下,會(huì)話窗口A的會(huì)話ID為85,會(huì)話窗口B的會(huì)話ID為90,會(huì)話窗口C的會(huì)話ID為87,如下所示

SQLServer,SELECT,阻塞

如下所示,你會(huì)看到SELECT語(yǔ)句“阻塞”了SELECT語(yǔ)句,即會(huì)話90“阻塞”了會(huì)話87, 它們的等待事件都為L(zhǎng)CK_M_S,也就是說它們都在等待獲取共享鎖,也許你會(huì)置疑這個(gè)SQL是否有問題,那么我們使用SP_WHO來查看,你會(huì)發(fā)現(xiàn)也是如此,如下所示:

SQLServer,SELECT,阻塞

如下所示,我們會(huì)發(fā)現(xiàn)會(huì)話ID為90 、87的會(huì)話都在等待類型為RID,Resource為1:24171:1的共享鎖

SQLServer,SELECT,阻塞

其實(shí)應(yīng)該說,會(huì)話87、90都在等待RID對(duì)象的共享鎖,我們知道共享鎖與意向共享鎖都是兼容的,所以SELECT是不會(huì)阻塞SELECT的,那么又怎么解釋這個(gè)現(xiàn)象呢?在宋大神的指點(diǎn)下,粗略的翻了Database System Implementaion這本書(很多原理性知識(shí),看起來相當(dāng)吃力)。里面介紹了在鎖表(lock table)以及Element Info、Handling Lock Requests、Handling Unlocks等概念,有一個(gè)有意思的圖所示,

SQLServer,SELECT,阻塞

 

在鎖表(lock table)里,elements info里的鎖的申請(qǐng)是在一個(gè)類似隊(duì)列的結(jié)構(gòu)。先進(jìn)先出機(jī)制,所以當(dāng)會(huì)話90先進(jìn)入隊(duì)列,它在等待共享鎖(S), 會(huì)話87也進(jìn)入隊(duì)列等待共享鎖(S),而且它在會(huì)話90的后面(即會(huì)話90這個(gè)elements info后面的Next指針指向會(huì)話87會(huì)話的事務(wù)),由于兩個(gè)會(huì)話都被阻塞,這兩個(gè)會(huì)話的Wait字段都是Yes,由于內(nèi)部某些機(jī)制,會(huì)話87顯示阻塞它的會(huì)話為90(這個(gè)是我個(gè)人臆測(cè),實(shí)際具體原因有待考究),實(shí)質(zhì)阻塞的源頭還是會(huì)話85. 當(dāng)會(huì)話85釋放排它鎖(X)后,會(huì)話隊(duì)列根據(jù)下面幾個(gè)原則來處理解鎖(Handling Unlocks):

1: First-come-first-served: Grant the lock request that has been waiting the longest. This strategy guarantees no starvation, the situation where a transaction can wait forever for a lock

先來先服務(wù)(隊(duì)列的原則):授予鎖等待時(shí)間最長(zhǎng)的鎖請(qǐng)求,這種策略保證不會(huì)餓死(翻譯感覺不貼切),即一個(gè)事務(wù)不會(huì)永遠(yuǎn)等待鎖的情況。

2. Priority to shared locks: First grant all the shared locks waiting. Then,grant one update lock, if there are any waiting. Only grant an exclusive lock if no others are waiting. This strategy can allow starvation, if a transaction is waiting for a U or X lock.

共享鎖優(yōu)先,首先授予所有等待共享鎖(S),然后授予其中一個(gè)更新鎖(U),如果有其它類型等待,只有在沒有其它鎖等待時(shí),才授予排它鎖、這一策略允許等待更新鎖或排它鎖的事務(wù)餓死(結(jié)束)

3. Priority to upgrading: If there is a transaction with a U lock waiting to upgrade it to an X lock, grant that first. Otherwise, follow one of the other strategies mentioned.

鎖升級(jí)優(yōu)先,如果有一個(gè)持有共享鎖(U)等待升級(jí)Wie排他鎖(X),那么先授予它排它鎖,否則采用前面已經(jīng)提到的策略中的一個(gè)。

按照這些原則,當(dāng)會(huì)話85釋放了排它鎖(X)后,調(diào)度器(Scheduler)應(yīng)該會(huì)根據(jù)先后順序依次授予會(huì)話90、87共享鎖(S),兩者的阻塞會(huì)幾乎同時(shí)消失。 這個(gè)可以也可以通過實(shí)驗(yàn)進(jìn)行一個(gè)大概的推斷, 在上面實(shí)驗(yàn)中,你可以手工取消90會(huì)話的查詢操作,然后再查看阻塞情況,就會(huì)發(fā)現(xiàn)會(huì)話87被85阻塞了。這個(gè)阻塞的源頭就變成了85,而不是90了。

PS:上面是個(gè)人結(jié)合一些知識(shí)和理解,做的一些膚淺的判斷與分析,如果不對(duì)的地方,敬請(qǐng)指正!

參考資料:

Database System Implementaion

總結(jié)

以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,如果有疑問大家可以留言交流,謝謝大家對(duì)VeVb武林網(wǎng)的支持。


注:相關(guān)教程知識(shí)閱讀請(qǐng)移步到MSSQL教程頻道。
發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 毛片视频网站在线观看 | 欧美性受xxxx白人性爽 | 国产精品自拍啪啪 | 欧美成人精品一区二区 | 日韩欧美高清一区 | 国产亚洲精品久久久久5区 日韩一级片一区二区三区 国产精品久久久久av | 国产精品成aⅴ人片在线观看 | 亚洲涩涩图 | 久久精品视频首页 | 国产精品一区二区三区在线播放 | 性高跟鞋xxxxhd4kvideos | 88xx成人永久免费观看 | 狠狠婷婷综合久久久久久妖精 | 日韩欧美视频一区二区三区 | 国产精品午夜未成人免费观看 | 视频一区二区在线播放 | 午夜视频国产 | 久草在线视频网 | 欧美视频99 | 天天黄色片 | 在线看免电影网站 | 久久精品一二三区白丝高潮 | 午夜精品在线视频 | 99seav| 一区二区三区四区高清视频 | 欧美国产精品一区二区 | 毛片视频大全 | 妇子乱av一区二区三区 | 一级国产电影 | 看一级大毛片 | 久久国产午夜 | 久久久一区二区三区精品 | 国产精品久久77777 | 一本色道久久综合狠狠躁篇适合什么人看 | 热99在线视频 | 久草视频手机在线观看 | 4p一女两男做爰在线观看 | 久久99国产视频 | 懂色粉嫩av久婷啪 | 国产欧美日韩视频在线观看 | sm高h视频|