一組原子性的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)站回饋大家。
BEGIN
BEGIN WORK
START TRANSACTION
# 提交
COMMIT
# 回滾
ROLLBACK
默認(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}
SAVEPOINT identifier
ROLLBACK [WORK] TO [SAVEPOINT] identifier
RELEASE SAVEPOINT identifier
# 查看當(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í)別 | 說(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(多版本并發(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ì)所有讀取的行都加鎖
# 語(yǔ)法:
set tx_isolatioin='value';
# 有效值
READ-UNCOMMITTED
READ-COMMITTED
REPEATABLE-READ
SERIALIZABLE
在/etc/my.cnf文件的[mysqld]塊中使用transaction-isolation選項(xiàng)設(shè)置
[mysqld]
transaction-isolation = value
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)
網(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)