国产精品电影_久久视频免费_欧美日韩国产激情_成年人视频免费在线播放_日本久久亚洲电影_久久都是精品_66av99_九色精品美女在线_蜜臀a∨国产成人精品_冲田杏梨av在线_欧美精品在线一区二区三区_麻豆mv在线看

面試被吊打系列 - 事務隔離級別

開發 前端
如果數據庫采用 讀未提交(READ UNCOMMITTED)這種隔離級別,會造成 臟讀。事務還沒提交別人就能看到,這樣就不能保證你讀取到的數據是最終的數據,萬一別人把事務回滾了,那就出現了臟數據問題。

[[376678]]

本文轉載自微信公眾號「JAVA日知錄」,作者單一色調。轉載本文請聯系JAVA日知錄公眾號。   

 小張:面試官,你好。我是來參加面試的。

面試官:你好,小張。我看了你的簡歷,精通MySQL數據庫。那你肯定知道事務吧,你能說說 事務有哪些特性 嗎?

小張:一個事務有4個特性,即ACID。

  • 原子性(Atomicity): 事務開始后的所有操作,要么全部成功要么全部失敗。
  • 一致性(Consistency): 事務開始前后數據庫的完整性約束沒有被破壞,比如:A向B轉錢,不可能出現A扣了錢,B沒收到錢。
  • 隔離性(Isolation):多個事務并發訪問時,事務之間是隔離的。
  • 持久性(Durability):事務完成后,事務對數據庫的操作被保存在了數據庫,不能回滾。

面試官:嗯,答的很對。那你說說事務有哪幾種隔離級別呢?

小張:事務隔離級別從高到低有四種隔離級別,分別是:串行化(SERIALIZABLE) 、可重復讀(REPEATABLE READ)、讀提交(READ COMMITTED)、讀未提交(READ UNCOMMITTED)。

面試官:嗯嗯,那你能說說這四種隔離級別分別會造成什么問題嗎?

(小張竊喜,我就知道你要這么問,還好我平時關注了 ‘ JAVA日知錄 ’ 的公眾號)

小張:好的,面試官。

如果數據庫采用 讀未提交(READ UNCOMMITTED)這種隔離級別,會造成 臟讀。事務還沒提交別人就能看到,這樣就不能保證你讀取到的數據是最終的數據,萬一別人把事務回滾了,那就出現了臟數據問題。

讀提交(READ COMMITTED)是指一個事務只能讀取到其他事務已經提交了的數據,這樣就不會出現臟讀的問題,但是它會帶來」不可重復讀 的問題。比如 A事務 將一個人的姓名從張三改成李四,B事務在A事務提交之前讀取到的是張三,但是在A事務提交之后就變成了李四。

可重復讀(REPEATABLE READ):可重復讀是為了解決READ COMMITTED帶來的不可重復讀問題,指的是事務不會讀取到其他事務對已有數據的修改,即使數據已經提交了。也就是說事務開始讀取到的是什么,在事務提交之前的任意時刻,這些數據都一樣。雖然解決了不可重復讀問題,但是他又會帶來 幻讀 的問題。比如A事務將張三修改成李四,B事務再插入一個名叫李四的用戶,此時事務A再查找名叫李四的用戶會發現多了一條,出現了2個李四,這就是幻讀。

串行化(SERIALIZABLE):解決了上面出現的所有問題,但是它效率最差,它將事務的執行變成順序執行了。

面試官:回答的不錯,那你知道 MySQL的默認隔離級別是什么嗎?

小張:Mysql默認的隔離級別是REPEATABLE READ,Oracle則采用的是READ COMMITTED。

面試官:但是我們使用MySQL的時候并沒有出現幻讀啊,怎么解決的?

小張擦了擦汗,開始有點緊張了:額,InnoDB主要是利用鎖來解決幻讀問題的。

面試官:對,是采用了鎖,那么具體怎么實現的呢?

 

小張:我...我突然有點事,我先回去了。

面試官:要了解InnoDB怎么解決幻讀得先知道InnoDB有哪幾種鎖。

  • Record Lock:單個行記錄上的鎖
  • Gap Lock:間隙鎖,鎖定一個范圍,而非記錄本身,遵循左開右閉原則
  • Next-Key Lock:結合Gap Lock和Record Lock,鎖定一個范圍,并且鎖定記錄本身。主要解決的問題是REPEATABLE READ隔離級別下的幻讀。

注意,如果走唯一索引,那么Next-Key Lock會降級為Record Lock,即僅鎖住索引本身,而不是范圍。也就是說Next-Key Lock前置條件為事務隔離級別為RR且查詢的索引走的非唯一索引、主鍵索引。

下面我們通過具體的例子來模擬上面出現的幻讀問題:

  1. CREATE TABLE T (id int ,name varchar(50),f_id int,PRIMARY KEY (id), KEY(f_id)) ENGINE=InnoDB DEFAULT CHARSET=utf8 
  2. insert into T SELECT 1,'張三',10; 
  3. insert into T SELECT 2,'李四',30; 

InnoDB在數據庫中會為索引維護一套B+樹,用來快速定位行記錄。B+索引樹是有序的,所以會把這張表的索引分割成幾個區間。

 

事務A執行如下語句,需要將張三修改成李四。

  1. select * from t; 
  2. update t set name = '李四' where f_id = 10; 

這時SQL語句走非唯一索引,因此使用Next-Key Lock加鎖,不僅會給f_10=10的行加上行鎖,而且還會給這條記錄的兩邊添加上間隙鎖,即(-∞,10]、(10,30]這2個區間都加了間隙鎖。


 

 

此時如果B事務要執行如下語句,都會報錯[Err] 1205 - Lock wait timeout exceeded; try restarting transaction

  1. INSERT INTO T SELECT 3,'王五',10;  -- 滿足行鎖,執行阻塞 
  2. INSERT INTO T SELECT 4,'趙六',8;   -- 滿足間隙鎖,執行阻塞 
  3. INSERT INTO T SELECT 5,'孫七',18;  -- 滿足間隙鎖,執行阻塞 

不僅插入 f_id = 10 的記錄需要等待事務A提交,f_id <10、10< f_id <30 的記錄也無法完成,而大于等于30的記錄則不受影響,這足以解決幻讀問題了。

剛剛講的是f_id 是索引列的情況,那么如果 f_id不是索引列會怎么樣呢?

這時候數據庫會為整個表加上間隙鎖。所以,如果是沒有索引的話,不管 f_id 是否大于等于30,都要等待事務A提交才可以成功插入。

面試官:好了,各位看官朋友們,事務的隔離級別這個面試點你們清楚了嗎?希望你們的面試不會被這個問題難倒喲~

小張:學到了學到了,我下次再來。(趕緊回去把簡歷上的精通數據庫給刪掉。)

責任編輯:武曉燕 來源: JAVA日知錄
相關推薦

2021-01-08 09:23:56

Redis緩存面試

2022-09-19 06:16:23

事務隔離級別Spring

2018-12-19 16:46:38

MySQL事務隔離數據庫

2010-11-19 16:13:06

oracle事務隔離級

2009-06-29 17:54:47

Spring事務隔離

2019-04-26 14:12:19

MySQL數據庫隔離級別

2022-06-29 11:01:05

MySQL事務隔離級別

2021-07-26 10:28:13

MySQL事務隔離

2024-04-26 09:17:20

MySQL事務隔離

2021-08-04 13:19:42

MySQL 事務隔離

2023-02-02 07:06:10

2024-12-02 08:37:04

2022-09-13 13:49:05

數據庫隔離

2022-10-09 20:52:19

事務隔離級別傳播機制

2021-10-19 10:10:51

MySQL事務隔離級別數據庫

2023-10-11 08:09:53

事務隔離級別

2021-09-02 18:39:01

Spring隔離級別

2025-03-03 08:20:00

MySQL事務隔離數據庫

2025-01-13 13:12:54

2020-10-13 10:32:24

MySQL事務MVCC
點贊
收藏

51CTO技術棧公眾號

久久久久999| 久久精品99久久久香蕉| 手机福利在线| 日韩精品一区国产| 亚洲精品一线二线三线无人区| 一区 二区 三区| 亚洲同性gay激情无套| 日韩av黄色| 亚洲免费成人av| 日本三级免费网站| 久久精品99国产精品| 精品视频第一区| 国产精品成人一区二区不卡| 日产精品99久久久久久| 91精品国产乱| 分分操这里只有精品| 免费成人av资源网| 欧美成人一区二区在线| 一区视频在线| 国产精品亚发布| 91国偷自产一区二区三区成为亚洲经典 | 欧美老少做受xxxx高潮| 黑人极品ⅴideos精品欧美棵| 欧美亚洲日本一区| 爱久久·www| 7777精品伊人久久久大香线蕉经典版下载 | 亚洲男人的天堂在线| 亚洲精品福利电影| 最近更新的2019中文字幕| www一区二区三区| 777777777亚洲妇女| 自拍视频一区| 91福利入口| 亚洲一区二区三区四区五区午夜| 欧美高清视频一区二区三区在线观看| 久久九九99| 国产曰肥老太婆无遮挡| 国产日本亚洲高清| 污污免费网站| 精品污污网站免费看| 成人超碰在线| 美女性感视频久久久| 国产videos久久| 国产日本欧美在线观看| 国产专区在线视频| 成人av资源在线| 性生交免费视频| 不卡av在线播放| 久久国内精品视频| 欧美一区观看| 久草在线在线精品观看| 日韩欧美视频免费在线观看| 波波电影院一区二区三区| 黄色片视频在线播放| 国产亚洲1区2区3区| 涩涩视频免费网站| 一本一道久久a久久精品| av一区在线观看| 亚洲精品国产精品国产自| 国精产品一区一区三区四川| 欧美另类在线播放| 久久久久久毛片免费看 | www.成人| 国产精品久久久久av免费| 中文字幕午夜精品一区二区三区| 久久人人97超碰人人澡爱香蕉| 国产一区二区三区精品欧美日韩一区二区三区 | 欧美日韩一区二区三区不卡视频| 国产精品一区二区在线| 999精品一区| 在线国产日本| 不卡av免费在线观看| 黄动漫视频高清在线| 亚洲精品久久久久中文字幕二区| 国产精品17p| 麻豆91蜜桃| 亚洲色图丝袜美腿| 97天天综合网| 国产精品久久中文| 成人精品视频一区二区三区 | 99精品欧美一区| av午夜在线| 51ⅴ精品国产91久久久久久| 日韩在线卡一卡二| 香蕉自在线视频| 久久九九免费视频| 久久一二三区| 女人体1963| 国产亚洲激情视频在线| 黄色精品免费| 2018av男人天堂| 原创国产精品91| 国产亚洲一区在线| 影音先锋在线影院| 久久天天躁狠狠躁夜夜躁2014 | 不卡一卡2卡3卡4卡精品在| 91麻豆精东视频| av2020不卡| 亚洲最大的av网站| 国产精品不卡在线| 成人激情综合| 久久免费看av| 偷窥少妇高潮呻吟av久久免费| 亚洲网站三级| 伊人久久青草| 欧美一区二区三区思思人| 欧美日韩伦理在线免费| 网站一区二区三区| www国产精品com| 国产在线一区二区综合免费视频| av在线电影播放| 91精品久久久久久久久青青 | 日韩在线影院| 成年人免费视频观看| 超碰个人在线| 国产精品成久久久久三级| 久久人人超碰| 手机福利在线| 精品www久久久久奶水| 五月综合激情婷婷六月色窝| 国产免费av国片精品草莓男男| 欧美r级在线| 99re6热在线精品视频播放| 亚洲欧美精品| 日韩av手机在线看| 亚洲精品乱码久久久久久金桔影视 | 国产成人免费视频网站| 青青草视频免费在线观看| 久久久久久久91| 蜜臀久久久久久久| 麻豆精品蜜桃| 久久久噜噜噜久久中文字幕色伊伊| 2020中文字幕在线播放| 亚洲国产中文字幕| 亚洲三级影院| а√天堂官网中文在线| 国产69精品久久久久999小说| 欧美色网在线| 九色视频网站在线观看| 国产亚洲福利社区| 国产视频在线一区二区| 精品高清美女精品国产区| 粉嫩av四季av绯色av第一区| 亚洲一区二区三区小说| 第一sis亚洲原创| 亚州黄色一级| 国产欧美日韩专区发布| 色综合av在线| 久久中文字幕一区二区三区| av今日在线| 91av资源网| 欧美一区二区三区精品电影| 亚洲国产婷婷综合在线精品| 欧美精品综合| av免费在线视| 日韩av资源在线| 国产精品久久久久久久久久ktv| 色综合视频一区二区三区高清| 国产精品www.| 羞羞网站在线看| 免费看av软件| 色综合男人天堂| 亚洲成人在线观看视频| 在线播放一区| 粉嫩一区二区三区| 欧美男女交配视频| 91色视频在线观看| 日韩视频免费观看高清完整版| 国产二区国产一区在线观看| 成人香蕉社区| www.久久热.com| 欧美久久久久久久久久久久久 | 日产国产高清一区二区三区| 亚洲一区站长工具| www成人免费视频| 国产精品制服诱惑| 在线看日韩欧美| 一区二区久久久久久| 久久一日本道色综合久久| 成人亚洲综合| 青青九九免费视频在线| 中国女人做爰视频| 国产精品久久久久久久久久新婚 | 青青视频在线观| 视频一区二区三区在线观看| 久久视频在线播放| 偷拍与自拍一区| 韩国精品一区二区| 免费毛片小视频| 日本久久久久久久久| 制服丝袜在线91| 久久九九久久九九| 国产欧美一区二区三区国产幕精品| 国产精品一区二区免费福利视频| h动漫在线视频| 国产又粗又猛又爽又黄的网站| 国产精品久久久久久久一区探花 | 国产精品爽爽爽| 国产亚洲精品美女| 亚洲一线二线三线视频|