MySQL事務(wù)和事務(wù)的四種隔離級(jí)別forINNODB

什么是事務(wù)

一組原子性的SQL語(yǔ)句,可以提交或回滾的原子工作單元 。當(dāng)事務(wù)對(duì)數(shù)據(jù)庫(kù)進(jìn)行多次更改時(shí),要么在提交事務(wù)后所有更改成功,要么在回滾事務(wù)時(shí)撤消所有更改。

公司主營(yíng)業(yè)務(wù):網(wǎng)站制作、網(wǎng)站設(shè)計(jì)、移動(dòng)網(wǎng)站開發(fā)等業(yè)務(wù)。幫助企業(yè)客戶真正實(shí)現(xiàn)互聯(lián)網(wǎng)宣傳,提高企業(yè)的競(jìng)爭(zhēng)能力。創(chuàng)新互聯(lián)建站是一支青春激揚(yáng)、勤奮敬業(yè)、活力青春激揚(yáng)、勤奮敬業(yè)、活力澎湃、和諧高效的團(tuán)隊(duì)。公司秉承以“開放、自由、嚴(yán)謹(jǐn)、自律”為核心的企業(yè)文化,感謝他們對(duì)我們的高要求,感謝他們從不同領(lǐng)域給我們帶來(lái)的挑戰(zhàn),讓我們激情的團(tuán)隊(duì)有機(jī)會(huì)用頭腦與智慧不斷的給客戶帶來(lái)驚喜。創(chuàng)新互聯(lián)建站推出濟(jì)源免費(fèi)做網(wǎng)站回饋大家。

事務(wù)特性

ACID特性
  • A: atomicity(原子性):整個(gè)事務(wù)中的所有操作要么全部成功,要么全部失敗后回滾;
  • C: consistency(一致性):整個(gè)數(shù)據(jù)庫(kù)總是從一個(gè)一致性狀態(tài)轉(zhuǎn)換為另一個(gè)一致性狀態(tài);
  • I: isolation(隔離性):一個(gè)事務(wù)所做的的操作在提交之前,是不被其它事務(wù)所見的;
  • D: durability(持久性):事務(wù)一旦提交,其所做的修改會(huì)永久保存于數(shù)據(jù)庫(kù)中。
事務(wù)生命周期

MySQL事務(wù)和事務(wù)的四種隔離級(jí)別 for INNODB

事務(wù)管理

顯式啟動(dòng)事務(wù):
BEGIN
BEGIN WORK
START TRANSACTION
結(jié)束事務(wù):
# 提交
COMMIT
# 回滾
ROLLBACK
注:只有事務(wù)型的存儲(chǔ)引擎的DML語(yǔ)句才能支持此類操作
自動(dòng)提交:
默認(rèn)為1,為0時(shí)設(shè)為非自動(dòng)提交
> show variables like 'autocommit';
+---------------+-------+
| Variable_name | Value |
+---------------+-------+
| autocommit    | ON    |
+---------------+-------+
1 row in set (0.00 sec)

set autocommit={1|0}
注:建議顯式請(qǐng)求和提交事務(wù),而不要使用“自動(dòng)提交”功能。
事務(wù)支持保存點(diǎn):
SAVEPOINT identifier
ROLLBACK [WORK] TO [SAVEPOINT] identifier
RELEASE SAVEPOINT identifier
查看事務(wù):
# 查看當(dāng)前的事務(wù)
SELECT * FROM INFORMATION_SCHEMA.INNODB_TRX;
#查看當(dāng)前鎖定的事務(wù)
SELECT * FROM INFORMATION_SCHEMA.INNODB_LOCKS;
#查看當(dāng)前等鎖的事務(wù)
SELECT * FROM INFORMATION_SCHEMA.INNODB_LOCK_WAITS;

事務(wù)隔離級(jí)別

MySQL事務(wù)支持四種隔離級(jí)別,從上至下更加嚴(yán)格
事務(wù)隔離級(jí)別說(shuō)明臟讀可能性不可重復(fù)讀可能性幻讀可能性加讀鎖
READ UNCOMMITTED 可讀取到未提交數(shù)據(jù),產(chǎn)生臟讀 Yes Yes Yes No
READ COMMITTED 可讀取到提交數(shù)據(jù),但未提交數(shù)據(jù)不可讀,產(chǎn)生不可重復(fù)讀,即可讀取到多個(gè)提交數(shù)據(jù),導(dǎo)致每次讀取的數(shù)據(jù)不一致 No Yes Yes No
REPEATABLE READ 可重復(fù)讀,多次讀取數(shù)據(jù)都一致,產(chǎn)生幻讀,即讀取過(guò)程中,即使有其它提交的事務(wù)修改數(shù)據(jù),仍只能讀取到未修改前的舊數(shù)據(jù)。此為MySQL默認(rèn)設(shè)置 Yes Yes Yes No
SERIALIZABLE 可串行化,未提交的讀事務(wù)阻塞修改事務(wù)(加讀鎖,但不阻塞讀事務(wù)),或者未提交的修改事務(wù)阻塞讀事務(wù)(加寫鎖,其它事務(wù)的讀,寫都不可以執(zhí)行)。會(huì)導(dǎo)致并發(fā)性能差 No No No Yes

MVCC和事務(wù)的隔離級(jí)別

MVCC(多版本并發(fā)控制機(jī)制)只在REPEATABLE READ和READ COMMITTED兩個(gè)隔離級(jí)別下工作。其他兩個(gè)隔離級(jí)別都和MVCC不兼容,因?yàn)镽EAD UNCOMMITTED總是讀取最新的數(shù)據(jù)行,而不是符合當(dāng)前事務(wù)版本的數(shù)據(jù)行。而SERIALIZABLE則會(huì)對(duì)所有讀取的行都加鎖

如何指定事務(wù)隔離級(jí)別

參考:https://dev.mysql.com/doc/refman/8.0/en/server-system-variables.html#sysvar_tx_isolation
1.系統(tǒng)變量tx_isolation指定,默認(rèn)為REPEATABLE-READ,有效范圍:Global, Session
# 語(yǔ)法:
set tx_isolatioin='value';
# 有效值
READ-UNCOMMITTED
READ-COMMITTED
REPEATABLE-READ
SERIALIZABLE
2.服務(wù)器選項(xiàng)中指定
在/etc/my.cnf文件的[mysqld]塊中使用transaction-isolation選項(xiàng)設(shè)置
[mysqld]
transaction-isolation = value

事務(wù)隔離級(jí)別驗(yàn)證

背景:通過(guò)兩個(gè)終端顯示啟動(dòng)兩個(gè)事務(wù)來(lái)驗(yàn)證,用作驗(yàn)證的user表的表內(nèi)容和表結(jié)構(gòu)如下
mysql> desc user;
+-------+------------------+------+-----+---------+----------------+
| Field | Type             | Null | Key | Default | Extra          |
+-------+------------------+------+-----+---------+----------------+
| id    | int(10) unsigned | NO   | PRI | NULL    | auto_increment |
| name  | varchar(30)      | NO   |     | NULL    |                |
+-------+------------------+------+-----+---------+----------------+
2 rows in set (0.00 sec)

mysql> select * from user;
+----+-------+
| id | name  |
+----+-------+
|  2 | root  |
|  3 | admin |
+----+-------+
2 rows in set (0.00 sec)
1.READ UNCOMMITTED級(jí)別

MySQL事務(wù)和事務(wù)的四種隔離級(jí)別 for INNODB

2.READ COMMITTED級(jí)別

MySQL事務(wù)和事務(wù)的四種隔離級(jí)別 for INNODB

3.REPEATABLE READ級(jí)別

MySQL事務(wù)和事務(wù)的四種隔離級(jí)別 for INNODB

4.SERIALIZABLE級(jí)別
未提交的讀事務(wù)阻塞修改事務(wù)(加讀鎖,但不阻塞讀事務(wù))

MySQL事務(wù)和事務(wù)的四種隔離級(jí)別 for INNODB

未提交的修改事務(wù)阻塞讀事務(wù)(加寫鎖,其它事務(wù)的讀、寫都不可以執(zhí)行)

MySQL事務(wù)和事務(wù)的四種隔離級(jí)別 for INNODB

注:此種事務(wù)隔離級(jí)別會(huì)導(dǎo)致并發(fā)性能差。

附加案例:如果一個(gè)事務(wù)產(chǎn)生了寫鎖,然后一直未結(jié)束事務(wù),這樣會(huì)導(dǎo)致其它事務(wù)的讀、寫都不可以執(zhí)行,對(duì)于這種情況,可以找到未結(jié)束并且導(dǎo)致阻塞的事務(wù),手動(dòng)將其kill。

拿上面未提交的修改事務(wù)阻塞讀事務(wù)的案例來(lái)驗(yàn)證

MySQL事務(wù)和事務(wù)的四種隔離級(jí)別 for INNODB

打開第三個(gè)會(huì)話執(zhí)行以下操作

MySQL事務(wù)和事務(wù)的四種隔離級(jí)別 for INNODB
MySQL事務(wù)和事務(wù)的四種隔離級(jí)別 for INNODB

死鎖

MySQL事務(wù)和事務(wù)的四種隔離級(jí)別 for INNODB

網(wǎng)頁(yè)標(biāo)題:MySQL事務(wù)和事務(wù)的四種隔離級(jí)別forINNODB
文章分享:http://bm7419.com/article38/pcippp.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供自適應(yīng)網(wǎng)站、云服務(wù)器、網(wǎng)站排名、移動(dòng)網(wǎng)站建設(shè)、靜態(tài)網(wǎng)站、網(wǎng)站維護(hù)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

成都網(wǎng)頁(yè)設(shè)計(jì)公司