久久r热视频,国产午夜精品一区二区三区视频,亚洲精品自拍偷拍,欧美日韩精品二区

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

java - innodb 中的行級(jí)別的鎖

瀏覽:117日期:2023-12-05 15:08:13

問(wèn)題描述

Innodb 實(shí)現(xiàn)了兩種行級(jí)別的鎖, 一個(gè)是共享鎖,一個(gè)是排它鎖。 請(qǐng)問(wèn):(1)行級(jí)別的鎖是不是只能加載行記錄上? 為什我看到有的地提到表級(jí)上也可以共享鎖和排它鎖呢?

各位可以提示下嗎

問(wèn)題解答

回答1:

InnoDB的行鎖只在鎖語(yǔ)句(也就是FOR UPDATE和LOCK IN SHARE MODE)使用到索引時(shí)才有效,因?yàn)镮nnoDB鎖的其實(shí)是根據(jù)索引鎖住行的。也就是說(shuō),如果沒(méi)有使用索引,鎖就會(huì)自動(dòng)提升到表級(jí)別。

回答2:

如果樓上所說(shuō),在事物隔離級(jí)別為repeat read下(mysql默認(rèn)級(jí)別)InnoDB引擎在修改刪除數(shù)據(jù)時(shí),會(huì)先查找到對(duì)應(yīng)的索引,索引都是排序了的,所以會(huì)鎖住某個(gè)值或者某個(gè)范圍。如果這個(gè)范圍是整個(gè)索引段,那么則整個(gè)表數(shù)據(jù)均會(huì)被鎖住;另外沒(méi)有索引,在做修改刪除操作的時(shí)候會(huì)全表掃描數(shù)據(jù),自然也會(huì)鎖全表。

回答3:

InnoDB實(shí)現(xiàn)了以下兩種類(lèi)型的行鎖。 共享鎖(s):允許一個(gè)事務(wù)去讀一行,阻止其他事務(wù)獲得相同數(shù)據(jù)集的排他鎖。 排他鎖(X):允許獲取排他鎖的事務(wù)更新數(shù)據(jù),阻止其他事務(wù)取得相同的數(shù)據(jù)集共享讀鎖和排他寫(xiě)鎖。另外,為了允許行鎖和表鎖共存,實(shí)現(xiàn)多粒度鎖機(jī)制,InnoDB還有兩種內(nèi)部使用的意向鎖(Intention Locks),這兩種意向鎖都是表鎖。 意向共享鎖(IS):事務(wù)打算給數(shù)據(jù)行共享鎖,事務(wù)在給一個(gè)數(shù)據(jù)行加共享鎖前必須先取得該表的IS鎖。 意向排他鎖(IX):事務(wù)打算給數(shù)據(jù)行加排他鎖,事務(wù)在給一個(gè)數(shù)據(jù)行加排他鎖前必須先取得該表的IX鎖。

行鎖是加在行上的,表鎖就是對(duì)應(yīng)整個(gè)表。行鎖和表鎖是可以共存的!

回答4:

鎖是mysql引擎都有的。行鎖和表鎖是在鎖粒度的角度上區(qū)分的

標(biāo)簽: java
相關(guān)文章:
主站蜘蛛池模板: 竹山县| 黄陵县| 松阳县| 平江县| 晋城| 宣武区| 贵德县| 洛川县| 防城港市| 东山县| 安平县| 迭部县| 冷水江市| 通许县| 喀喇| 开封市| 密山市| 克拉玛依市| 嘉义县| 亳州市| 宁南县| 体育| 顺平县| 清水县| 石泉县| 大连市| 黎川县| 长葛市| 许昌市| 基隆市| 西贡区| 阿坝县| 苏尼特右旗| 新泰市| 金华市| 东乌珠穆沁旗| 玛纳斯县| 越西县| 客服| 炉霍县| 顺平县|