成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

一文帶你輕松搞懂事務隔離級別(圖文詳解)

數據庫 MySQL
事務是邏輯上的一組操作,要么都執行,要么都不執行。

 什么是事務?

事務是邏輯上的一組操作,要么都執行,要么都不執行。

[[315803]]

事務最經典也經常被拿出來說例子就是轉賬了。假如小明要給小紅轉賬1000元,這個轉賬會涉及到兩個關鍵操作就是:將小明的余額減少1000元,將小紅的余額增加1000元。萬一在這兩個操作之間突然出現錯誤比如銀行系統崩潰,導致小明余額減少而小紅的余額沒有增加,這樣就不對了。事務就是保證這兩個關鍵操作要么都成功,要么都要失敗。

事物的特性(ACID)

一文帶你輕松搞懂事務隔離級別(圖文詳解)

原子性: 事務是最小的執行單位,不允許分割。事務的原子性確保動作要么全部完成,要么完全不起作用;

一致性: 執行事務前后,數據保持一致;

隔離性: 并發訪問數據庫時,一個用戶的事物不被其他事物所干擾,各并發事務之間數據庫是獨立的;

持久性: 一個事務被提交之后。它對數據庫中數據的改變是持久的,即使數據庫發生故障也不應該對其有任何影響。

并發事務帶來的問題

在典型的應用程序中,多個事務并發運行,經常會操作相同的數據來完成各自的任務(多個用戶對統一數據進行操作)。并發雖然是必須的,但可能會導致以下的問題。

臟讀(Dirty read): 當一個事務正在訪問數據并且對數據進行了修改,而這種修改還沒有提交到數據庫中,這時另外一個事務也訪問了這個數據,然后使用了這個數據。因為這個數據是還沒有提交的數據,那么另外一個事務讀到的這個數據是“臟數據”,依據“臟數據”所做的操作可能是不正確的。

丟失修改(Lost to modify): 指在一個事務讀取一個數據時,另外一個事務也訪問了該數據,那么在第一個事務中修改了這個數據后,第二個事務也修改了這個數據。這樣第一個事務內的修改結果就被丟失,因此稱為丟失修改。例如:事務1讀取某表中的數據A=20,事務2也讀取A=20,事務1修改A=A-1,事務2也修改A=A-1,最終結果A=19,事務1的修改被丟失。

不可重復讀(Unrepeatableread): 指在一個事務內多次讀同一數據。在這個事務還沒有結束時,另一個事務也訪問該數據。那么,在第一個事務中的兩次讀數據之間,由于第二個事務的修改導致第一個事務兩次讀取的數據可能不太一樣。這就發生了在一個事務內兩次讀到的數據是不一樣的情況,因此稱為不可重復讀。

幻讀(Phantom read): 幻讀與不可重復讀類似。它發生在一個事務(T1)讀取了幾行數據,接著另一個并發事務(T2)插入了一些數據時。在隨后的查詢中,第一個事務(T1)就會發現多了一些原本不存在的記錄,就好像發生了幻覺一樣,所以稱為幻讀。

不可重復度和幻讀區別:

不可重復讀的重點是修改,幻讀的重點在于新增或者刪除。

例1(同樣的條件, 你讀取過的數據, 再次讀取出來發現值不一樣了 ):事務1中的A先生讀取自己的工資為 1000的操作還沒完成,事務2中的B先生就修改了A的工資為2000,導 致A再讀自己的工資時工資變為 2000;這就是不可重復讀。

例2(同樣的條件, 第1次和第2次讀出來的記錄數不一樣 ):假某工資單表中工資大于3000的有4人,事務1讀取了所有工資大于3000的人,共查到4條記錄,這時事務2 又插入了一條工資大于3000的記錄,事務1再次讀取時查到的記錄就變為了5條,這樣就導致了幻讀。

事務隔離級別

SQL 標準定義了四個隔離級別:

READ-UNCOMMITTED(讀取未提交): 最低的隔離級別,允許讀取尚未提交的數據變更,可能會導致臟讀、幻讀或不可重復讀

READ-COMMITTED(讀取已提交): 允許讀取并發事務已經提交的數據,可以阻止臟讀,但是幻讀或不可重復讀仍有可能發生

REPEATABLE-READ(可重讀): 對同一字段的多次讀取結果都是一致的,除非數據是被本身事務自己所修改,可以阻止臟讀和不可重復讀,但幻讀仍有可能發生。

SERIALIZABLE(可串行化): 最高的隔離級別,完全服從ACID的隔離級別。所有的事務依次逐個執行,這樣事務之間就完全不可能產生干擾,也就是說,該級別可以防止臟讀、不可重復讀以及幻讀

MySQL InnoDB 存儲引擎的默認支持的隔離級別是 REPEATABLE-READ(可重讀)。我們可以通過SELECT @@tx_isolation;命令來查看

mysql> SELECT @@tx_isolation;
+-----------------+
| @@tx_isolation |
+-----------------+
| REPEATABLE-READ |
+-----------------+

這里需要注意的是:與 SQL 標準不同的地方在于InnoDB 存儲引擎在 REPEATABLE-READ(可重讀)事務隔離級別下使用的是Next-Key Lock 鎖算法,因此可以避免幻讀的產生,這與其他數據庫系統(如 SQL Server)是不同的。所以說InnoDB 存儲引擎的默認支持的隔離級別是 REPEATABLE-READ(可重讀) 已經可以完全保證事務的隔離性要求,即達到了 SQL標準的SERIALIZABLE(可串行化)隔離級別。

因為隔離級別越低,事務請求的鎖越少,所以大部分數據庫系統的隔離級別都是READ-COMMITTED(讀取提交內容):,但是你要知道的是InnoDB 存儲引擎默認使用REPEATABLE-READ(可重讀)并不會有任何性能損失。

InnoDB 存儲引擎在 分布式事務 的情況下一般會用到SERIALIZABLE(可串行化)隔離級別。

實際情況演示

MySQL 命令行的默認配置中事務都是自動提交的,即執行SQL語句后就會馬上執行 COMMIT 操作。如果要顯式地開啟一個事務需要使用命令:START TARNSACTION。

我們可以通過下面的命令來設置隔離級別。

SET [SESSION|GLOBAL] TRANSACTION ISOLATION LEVEL [READ UNCOMMITTED|READ COMMITTED|REPEATABLE READ|SERIALIZABLE]

我們再來看一下我們在下面實際操作中使用到的一些并發控制語句:

•START TARNSACTION |BEGIN:顯式地開啟一個事務。

•COMMIT:提交事務,使得對數據庫做的所有修改成為永久性。

•ROLLBACK 回滾會結束用戶的事務,并撤銷正在進行的所有未提交的修改。

在下面我會使用 2 個命令行 MySQL ,模擬多線程(多事務)。

臟讀(讀未提交)

一文帶你輕松搞懂事務隔離級別(圖文詳解)

 

避免臟讀(讀已提交)

一文帶你輕松搞懂事務隔離級別(圖文詳解)

 

不可重復讀

還是剛才上面的讀已提交的圖,雖然避免了讀未提交,但是卻出現了,一個事務還沒有結束,就發生了 不可重復讀問題。

一文帶你輕松搞懂事務隔離級別(圖文詳解)

 

可重復讀

一文帶你輕松搞懂事務隔離級別(圖文詳解)

 

防止幻讀(可重復讀)

一文帶你輕松搞懂事務隔離級別(圖文詳解)

 

一個事務對數據庫進行操作,這種操作的范圍是數據庫的全部行,然后第二個事務也在對這個數據庫操作,這種操作可以是插入一行記錄或刪除一行記錄,那么第一個是事務就會覺得自己出現了幻覺,怎么還有沒有處理的記錄呢? 或者 怎么多處理了一行記錄呢?

幻讀和不可重復讀有些相似之處 ,但是不可重復讀的重點是修改,幻讀的重點在于新增或者刪除。

責任編輯:武曉燕 來源: 今日頭條
相關推薦

2021-10-19 10:10:51

MySQL事務隔離級別數據庫

2023-03-06 21:29:41

mmap技術操作系統

2010-11-19 16:13:06

oracle事務隔離級

2020-04-07 09:21:45

MySQL數據庫SQL

2024-11-19 13:20:55

2021-09-07 09:46:40

JavaScriptGenerator函數

2021-09-11 10:41:27

PythonPickle模塊

2023-03-31 13:01:31

PythonCelery驗證

2021-11-06 10:18:30

Python變量常量

2022-05-11 11:54:55

Http傳送協議

2022-03-24 08:51:48

Redis互聯網NoSQL

2021-08-05 06:54:05

觀察者訂閱設計

2021-12-01 11:40:14

Python 輸入輸出

2021-10-13 21:43:18

JVMRPC框架

2021-07-21 09:24:25

MongoDB數據庫 Python

2024-04-12 12:19:08

語言模型AI

2024-12-02 08:37:04

2020-03-18 13:40:03

Spring事數據庫代碼

2021-09-28 07:12:10

avaScriptCurrying柯里化

2019-04-03 09:27:01

MySQLInnoDB務ACID
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 成人在线观看免费 | 亚洲免费视频网站 | 久久久久久久久99 | 亚洲精品一区二三区不卡 | 成人福利网站 | 99re热精品视频国产免费 | 久久久久亚洲精品 | 中文字幕在线欧美 | 一区二区三区小视频 | 亚洲国产精品一区 | 亚洲欧美综合网 | 精品一区二区三区四区视频 | 91一区二区 | 欧美激情视频网站 | 欧美成人a∨高清免费观看 色999日韩 | 欧美在线综合 | 一二三区视频 | 久久久精品综合 | 亚洲区视频 | 欧美国产日韩一区 | 91av在线影院 | 成年男女免费视频网站 | 国产一伦一伦一伦 | 99久久久久国产精品免费 | 1级毛片 | 精品欧美二区 | 久久久久成人精品亚洲国产 | 国产精品免费一区二区三区 | 在线婷婷 | 国产在线精品一区二区三区 | 天堂综合 | 国产乱码高清区二区三区在线 | 国产精品区二区三区日本 | 国产一级视屏 | 9191在线播放| 久久久999成人 | 一级a性色生活片久久毛片 午夜精品在线观看 | 97中文视频 | 自拍亚洲 | 一区二区三区高清在线观看 | 992人人草 |