MySQL數(shù)據(jù)庫(kù)事務(wù)原理及應(yīng)用
1 事務(wù)的使用
1.1 事務(wù)概念
事務(wù)就是一組DML語(yǔ)句組成,這些語(yǔ)句在邏輯上存在相關(guān)性,這一組DML語(yǔ)句要么全部成功,要么全部失敗,是一個(gè)整體。MySQL提供一種機(jī)制,保證我們達(dá)到這樣的效果。事務(wù)還規(guī)定不同的客戶端看到的數(shù)據(jù)是不相同的。
事務(wù)就是要做的或所做的事情,主要用于處理操作量大,復(fù)雜度高的數(shù)據(jù)。假設(shè)一種場(chǎng)景:你畢業(yè)了,學(xué)校的教務(wù)系統(tǒng)后臺(tái) MySQL 中,不在需要你的數(shù)據(jù),要?jiǎng)h除你的所有信息(一般不會(huì):) ), 那么要?jiǎng)h除你的基本信息(姓名,電話,籍貫等)的同時(shí),也刪除和你有關(guān)的其他信息,比如:你的各科成績(jī),你在校表現(xiàn),甚至你在論壇發(fā)過(guò)的文章等。這樣,就需要多條 MySQL 語(yǔ)句構(gòu)成,那么所有這些操作合起來(lái),就構(gòu)成了一個(gè)事務(wù)。
正如我們上面所說(shuō),一個(gè) MySQL 數(shù)據(jù)庫(kù),可不止你一個(gè)事務(wù)在運(yùn)行,同一時(shí)刻,甚至有大量的請(qǐng)求被包裝成事務(wù),在向 MySQL 服務(wù)器發(fā)起事務(wù)處理請(qǐng)求。而每條事務(wù)至少一條 SQL ,最多很多 SQL ,這樣如果大家都訪問(wèn)同樣的表數(shù)據(jù),在不加保護(hù)的情況,就絕對(duì)會(huì)出現(xiàn)問(wèn)題。甚至,因?yàn)槭聞?wù)由多條 SQL 構(gòu)成,那么,也會(huì)存在執(zhí)行到一半出錯(cuò)或者不想再執(zhí)行的情況,那么已經(jīng)執(zhí)行的怎么辦呢?
所以,一個(gè)完整的事務(wù),絕對(duì)不是簡(jiǎn)單的 sql 集合,還需要滿足如下四個(gè)屬性:
- 原子性:一個(gè)事務(wù)(transaction)中的所有操作,要么全部完成,要么全部不完成,不會(huì)結(jié)束在中間某個(gè)環(huán)節(jié)。事務(wù)在執(zhí)行過(guò)程中發(fā)生錯(cuò)誤,會(huì)被回滾(Rollback)到事務(wù)開(kāi)始前的狀態(tài),就像這個(gè)事務(wù)從來(lái)沒(méi)有執(zhí)行過(guò)一樣。
- 一致性:在事務(wù)開(kāi)始之前和事務(wù)結(jié)束以后,數(shù)據(jù)庫(kù)的完整性沒(méi)有被破壞。這表示寫(xiě)入的資料必須完全符合所有的預(yù)設(shè)規(guī)則,這包含資料的精確度、串聯(lián)性以及后續(xù)數(shù)據(jù)庫(kù)可以自發(fā)性地完成預(yù)定的工作。
- 隔離性:數(shù)據(jù)庫(kù)允許多個(gè)并發(fā)事務(wù)同時(shí)對(duì)其數(shù)據(jù)進(jìn)行讀寫(xiě)和修改的能力,隔離性可以防止多個(gè)事務(wù)并發(fā)執(zhí)行時(shí)由于交叉執(zhí)行而導(dǎo)致數(shù)據(jù)的不一致。事務(wù)隔離分為不同級(jí)別,包括讀未提交( Read uncommitted )、讀提交( read committed )、可重復(fù)讀( repeatable read )和串行化( Serializable )
- 持久性:事務(wù)處理結(jié)束后,對(duì)數(shù)據(jù)的修改就是永久的,即便系統(tǒng)故障也不會(huì)丟失
1.2 事務(wù)的提交
事務(wù)的提交方式常見(jiàn)的有兩種:
- 自動(dòng)提交
- 手動(dòng)提交
查看事務(wù)提交方式
mysql> show variables like 'autocommit'; +---------------+-------+ | Variable_name | Value | +---------------+-------+ | autocommit | ON | +---------------+-------+ 1 row in set (0.41 sec)
用 SET 來(lái)改變 MySQL 的自動(dòng)提交模式
mysql> SET AUTOCOMMIT=0; #SET AUTOCOMMIT=0 禁止自動(dòng)提交 Query OK, 0 rows affected (0.00 sec) mysql> show variables like 'autocommit'; +---------------+-------+ | Variable_name | Value | +---------------+-------+ | autocommit | OFF | +---------------+-------+ 1 row in set (0.00 sec) mysql> SET AUTOCOMMIT=1; #SET AUTOCOMMIT=1 開(kāi)啟自動(dòng)提交 Query OK, 0 rows affected (0.00 sec) mysql> show variables like 'autocommit'; +---------------+-------+ | Variable_name | Value | +---------------+-------+ | autocommit | ON | +---------------+-------+ 1 row in set (0.01 sec)
1.3 事務(wù)的常見(jiàn)操作
開(kāi)啟事務(wù):start transaction;
執(zhí)行多條SQL語(yǔ)句
回滾或提交:rollback/commit;
說(shuō)明:rollback即是全部失敗,commit即是全部成功
2 事務(wù)隔離
2.1 事務(wù)并發(fā)時(shí)出現(xiàn)的問(wèn)題
臟讀(第一個(gè)事務(wù)修改數(shù)據(jù)但沒(méi)有提交,第二個(gè)事務(wù)就讀取,在第一個(gè)事務(wù)回滾后,第二個(gè)事務(wù)讀取的就是臟數(shù)據(jù))
不可重復(fù)讀(一個(gè)事務(wù)兩次讀取數(shù)據(jù),中間有另一個(gè)事務(wù)修改,第一個(gè)事務(wù)兩次讀取的數(shù)據(jù)就不同)
幻讀 一個(gè)事務(wù)兩次讀取,中間有另一個(gè)事務(wù)執(zhí)行了插入操作,造成第一個(gè)事務(wù)看到不同的結(jié)果
2.2 事務(wù)隔離級(jí)別
讀未提交(Read Uncommitted): 在該隔離級(jí)別,所有的事務(wù)都可以看到其他事務(wù)沒(méi)有提交的執(zhí)行結(jié)果。(實(shí)際生產(chǎn)中不可能使用這種隔離級(jí)別的),但是相當(dāng)于沒(méi)有任何隔離性,也會(huì)有很多并發(fā)問(wèn)題,如臟讀,幻讀,不可重復(fù)讀等,我們上面為了做實(shí)驗(yàn)方便,用的就是這個(gè)隔離性。
讀提交(Read Committed) :該隔離級(jí)別是大多數(shù)數(shù)據(jù)庫(kù)的默認(rèn)的隔離級(jí)別(不是 MySQL 默認(rèn)的)。它滿足了隔離的簡(jiǎn)單定義:一個(gè)事務(wù)只能看到其他的已經(jīng)提交的事務(wù)所做的改變。這種隔離級(jí)別會(huì)引起不可重復(fù)讀,即一個(gè)事務(wù)執(zhí)行時(shí),如果多次 select, 可能得到不同的結(jié)果。
可重復(fù)讀(Repeatable Read): 這是 MySQL 默認(rèn)的隔離級(jí)別,它確保同一個(gè)事務(wù),在執(zhí)行中,多次讀取操作數(shù)據(jù)時(shí),會(huì)看到同樣的數(shù)據(jù)行。但是會(huì)有幻讀問(wèn)題。
串行化(Serializable): 這是事務(wù)的最高隔離級(jí)別,它通過(guò)強(qiáng)制事務(wù)排序,使之不可能相互沖突,從而解決了幻讀的問(wèn)題。它在每個(gè)讀的數(shù)據(jù)行上面加上共享鎖。但是可能會(huì)導(dǎo)致超時(shí)和鎖競(jìng)爭(zhēng)(這種隔離級(jí)別太極端,實(shí)際生產(chǎn)基本不使用)
隔離級(jí)別 | 臟讀 | 不可重復(fù)讀 | 幻讀 |
---|---|---|---|
讀未提交 | × | × | × |
讀提交 | √ | × | × |
可重復(fù)讀 | √ | √ | × |
串行化 | √ | √ | √ |
到此這篇關(guān)于MySQL數(shù)據(jù)庫(kù)事務(wù)原理及應(yīng)用的文章就介紹到這了,更多相關(guān)MySQL數(shù)據(jù)庫(kù)事務(wù)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- MySQL數(shù)據(jù)庫(kù)的觸發(fā)器和事務(wù)
- MySQL關(guān)系型數(shù)據(jù)庫(kù)事務(wù)的ACID特性與實(shí)現(xiàn)
- Mysql數(shù)據(jù)庫(kù)事務(wù)的臟讀幻讀及不可重復(fù)讀詳解
- MySQL數(shù)據(jù)庫(kù)表被鎖、解鎖以及刪除事務(wù)詳解
- MySQL數(shù)據(jù)庫(kù)本地事務(wù)原理解析
- MySQL 數(shù)據(jù)庫(kù) 索引和事務(wù)
- MySQL數(shù)據(jù)庫(kù)事務(wù)transaction示例講解教程
- MySQL數(shù)據(jù)庫(kù)的事務(wù)和索引詳解
相關(guān)文章
mysql xtrabackup 備份恢復(fù)實(shí)現(xiàn)分享
Xtrabackup是由percona提供的mysql數(shù)據(jù)庫(kù)備份工具,據(jù)官方介紹,這也是世界上惟一一款開(kāi)源的能夠?qū)nnodb和xtradb數(shù)據(jù)庫(kù)進(jìn)行熱備的工具2012-11-11MySQL數(shù)據(jù)庫(kù)學(xué)習(xí)之查詢操作詳解
這篇文章主要為大家詳細(xì)介紹一下MySQL數(shù)據(jù)庫(kù)中一些查詢操作,文中的示例代碼講解詳細(xì),對(duì)我們學(xué)習(xí)MySQL有一定幫助,需要的可以參考一下2022-07-07mysql從執(zhí)行.sql文件時(shí)處理\n換行的問(wèn)題
后來(lái)注意到,在上面我們恢復(fù)數(shù)據(jù)的時(shí)候是在沒(méi)有連接數(shù)據(jù)的狀態(tài)下執(zhí)行的。2009-05-05mybatis in語(yǔ)句不能大于1000的問(wèn)題及解決
這篇文章主要介紹了mybatis in語(yǔ)句不能大于1000的問(wèn)題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-11-11