国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術文章
文章詳情頁

java - innodb 中的行級別的鎖

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

問題描述

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

各位可以提示下嗎

問題解答

回答1:

InnoDB的行鎖只在鎖語句(也就是FOR UPDATE和LOCK IN SHARE MODE)使用到索引時才有效,因為InnoDB鎖的其實是根據索引鎖住行的。也就是說,如果沒有使用索引,鎖就會自動提升到表級別。

回答2:

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

回答3:

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

行鎖是加在行上的,表鎖就是對應整個表。行鎖和表鎖是可以共存的!

回答4:

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

標簽: java
相關文章:
主站蜘蛛池模板: 18成人免费观看网站入口 | 国产一级毛片午夜 | 精品久久久久久亚洲 | 亚洲精品久久久中文字 | 一区二区三区高清视频在线观看 | 亚洲欧美日韩综合久久久久 | 亚欧成人一区二区 | 黄色国产在线观看 | 日本www高清 | 成人精品一区久久久久 | 亚洲精品美女 | 国产成人精品久久亚洲高清不卡 | 日韩视频在线观看中字 | 手机看片手机在线看片 | 一本色道久久88亚洲精品综合 | 亚洲高清国产品国语在线观看 | 玖玖精品国产 | 日韩中文字幕在线观看视频 | 久久在线精品 | 午夜精品久久久久久91 | 国产在线观看网址你懂得 | 日本黄网站高清色大全 | 久久一区二区精品综合 | 18videosex性欧美69超高清 | 爱呦视频在线播放网址 | 亚洲天堂男人网 | 一区二区中文字幕亚洲精品 | 九九精品激情在线视频 | 久久观看| 伊人久久大香线焦综合四虎 | 荡女妇边被c边呻吟久久 | 国产精品视频第一区二区三区 | 国产成人毛片亚洲精品不卡 | 亚洲羞羞裸色私人影院 | 成人欧美精品一区二区不卡 | 国产成人福利美女观看视频 | 一本大道香蕉久在线不卡视频 | 欧美大尺度xxxxx视频 | 久草福利社| 最新国产三级久久 | 久久99这里只有精品国产 |