日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

MySQL锁的用法之行级锁

發(fā)布時(shí)間:2024/9/20 数据库 25 豆豆
生活随笔 收集整理的這篇文章主要介紹了 MySQL锁的用法之行级锁 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

轉(zhuǎn):http://www.kubiji.cn/topic-id2510.html
行級(jí)鎖是mysql中粒度最小的一種鎖,他能大大減少數(shù)據(jù)庫操作的沖突。但是粒度越小,實(shí)現(xiàn)的成本也越高。myisam引擎只支持表級(jí)鎖,而innodb引擎能夠支持行級(jí)鎖,下面的內(nèi)容也是針對(duì)INNODB行級(jí)鎖展開的。

INNODB的行級(jí)鎖有共享鎖(S LOCK)和排他鎖(X LOCK)兩種。共享鎖允許事物讀一行記錄,不允許任何線程對(duì)該行記錄進(jìn)行修改。排他鎖允許當(dāng)前事物刪除或更新一行記錄,其他線程不能操作該記錄。

? 共享鎖:
用法: SELECT ... LOCK IN SHARE MODE;

MySQL會(huì)對(duì)查詢結(jié)果集中每行都添加共享鎖。

鎖申請(qǐng)前提:當(dāng)前沒有線程對(duì)該結(jié)果集中的任何行使用排他鎖,否則申請(qǐng)會(huì)阻塞。

操作限制:

使用共享鎖線程與不使用共享鎖線程對(duì)鎖定記錄操作限制表



線程 讀取操作 寫入操作 共享鎖申請(qǐng) 排他鎖申請(qǐng)
使用共享鎖 可讀 可寫/不可寫(報(bào)錯(cuò)) 可申請(qǐng) 可申請(qǐng)
不使用共享鎖 可讀 不可寫(阻塞) 可申請(qǐng) 不可申請(qǐng)(阻塞)


1. 使用共享鎖線程可對(duì)其鎖定記錄進(jìn)行讀取,其他線程同樣也可對(duì)鎖定記錄進(jìn)行讀取操作,并且這兩個(gè)線程讀取的數(shù)據(jù)都屬于同一個(gè)版本。

2. 對(duì)于寫入操作,使用共享鎖的線程需要分情況討論,當(dāng)只有當(dāng)前線程對(duì)指定記錄使用共享鎖時(shí),線程是可對(duì)該記錄進(jìn)行寫入操作(包括更新與刪除),這是由于在寫入操作前,線程向該記錄申請(qǐng)了排他鎖,然后才進(jìn)行寫入操作;當(dāng)其他線程也對(duì)該記錄使用共享鎖時(shí),則不可進(jìn)行寫入操作,系統(tǒng)會(huì)有報(bào)錯(cuò)提示。不對(duì)鎖定記錄使用共享鎖的線程,當(dāng)然是不可進(jìn)行寫入操作了,寫入操作會(huì)阻塞。

3. 使用共享鎖進(jìn)程可再次對(duì)鎖定記錄申請(qǐng)共享鎖,系統(tǒng)并不報(bào)錯(cuò),但是操作本身并沒有太大意義。其他線程同樣也可以對(duì)鎖定記錄申請(qǐng)共享鎖。

4. 使用共享鎖進(jìn)程可對(duì)其鎖定記錄申請(qǐng)排他鎖;而其他進(jìn)程是不可以對(duì)鎖定記錄申請(qǐng)排他鎖,申請(qǐng)會(huì)阻塞。
? 排他鎖:

用法: SELECT ... FOR UPDATE;

MySQL會(huì)對(duì)查詢結(jié)果集中每行都添加排他鎖,在事物操作中,任何對(duì)記錄的更新與刪除操作會(huì)自動(dòng)加上排他鎖。

??? 鎖申請(qǐng)前提:當(dāng)前沒有線程對(duì)該結(jié)果集中的任何行使用排他鎖或共享鎖,否則申請(qǐng)會(huì)阻塞。

操作限制:

使用排他鎖線程與不使用排他鎖線程對(duì)鎖定記錄操作限制表

線程 讀取操作 寫入操作 共享鎖申請(qǐng) 排他鎖申請(qǐng)
使用排他鎖 可讀(新版本) 可寫 可申請(qǐng) 可申請(qǐng)
不使用排他鎖 可讀(舊版本) 不可寫(阻塞) 不可申請(qǐng)(阻塞) 不可申請(qǐng)(阻塞)


1. 使用排他鎖線程可以對(duì)其鎖定記錄進(jìn)行讀取,讀取的內(nèi)容為當(dāng)前事物的最新版本;而對(duì)于不使用排他鎖的線程,同樣是可以進(jìn)行讀取操作,這種特性是一致性非鎖定讀。即對(duì)于同一條記錄,數(shù)據(jù)庫記錄多個(gè)版本,在事物內(nèi)的更新操作會(huì)反映到新版本中,而舊版本會(huì)提供給其他線程進(jìn)行讀取操作。

2. 使用排他鎖線程可對(duì)其鎖定記錄進(jìn)行寫入操作;對(duì)于不使用排他鎖的線程,對(duì)鎖定記錄的寫操作是不允許的,請(qǐng)求會(huì)阻塞。

3. 使用排他鎖進(jìn)程可對(duì)其鎖定記錄申請(qǐng)共享鎖,但是申請(qǐng)共享鎖之后,線程并不會(huì)釋放原先的排他鎖,因此該記錄對(duì)外表現(xiàn)出排他鎖的性質(zhì);其他線程是不可對(duì)已鎖定記錄申請(qǐng)共享鎖,請(qǐng)求會(huì)阻塞。

4. 使用排他鎖進(jìn)程可對(duì)其鎖定記錄申請(qǐng)排他鎖(實(shí)際上并沒有任何意義);而其他進(jìn)程是不可對(duì)鎖定記錄申請(qǐng)排他鎖,申請(qǐng)會(huì)阻塞。

來源:http://www.thinkphp.cn/topic/44905.html

總結(jié)

以上是生活随笔為你收集整理的MySQL锁的用法之行级锁的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。