您好,登錄后才能下訂單哦!
這篇文章將為大家詳細(xì)講解有關(guān)MySQL事務(wù)是什么,小編覺得挺實(shí)用的,因此分享給大家做個(gè)參考,希望大家閱讀完這篇文章后可以有所收獲。
MySQL事務(wù)以及事務(wù)隔離級(jí)別
MySQL事務(wù)主要用于處理操作量大,復(fù)雜度高的數(shù)據(jù)。比如在人員管理系統(tǒng)中,你刪除一個(gè)人員,你就要?jiǎng)h除人員的基本資料,也要?jiǎng)h除和該人員相關(guān)的信息,如信箱,文章等,這些數(shù)據(jù)庫(kù)操作語(yǔ)句就構(gòu)成了一個(gè)事務(wù)(推薦課程:MySQL教程)
MySQL中只有使用了Innodb數(shù)據(jù)庫(kù)引擎的數(shù)據(jù)庫(kù)或表才支持事務(wù)
事務(wù)處理可以用來(lái)維護(hù)數(shù)據(jù)庫(kù)的完整性,保證成批的SQL語(yǔ)句要么全部執(zhí)行,要么全部不執(zhí)行
事務(wù)用來(lái)管理insert,update,delete語(yǔ)句
一般來(lái)說,事務(wù)必須滿足4個(gè)條件:原子性,一致性,隔離性,持久性
原子性:一個(gè)事務(wù)中所有操作,要么全部執(zhí)行,要么全部不執(zhí)行不會(huì)結(jié)束在中間某個(gè)環(huán)節(jié)。事務(wù)在執(zhí)行過程中發(fā)生錯(cuò)誤會(huì)被回滾到事務(wù)開始前的狀態(tài)
一致性:在事務(wù)開始之前和事務(wù)結(jié)束以后,數(shù)據(jù)庫(kù)的完整性沒有被破壞。這表示寫入的資料必須完全符合所有的預(yù)設(shè)規(guī)則,包含資料的精確度,串聯(lián)性以及后續(xù)數(shù)據(jù)庫(kù)可以自發(fā)性的完成預(yù)定的工作
隔離性:數(shù)據(jù)庫(kù)允許多個(gè)并發(fā)事務(wù)同時(shí)對(duì)其數(shù)據(jù)進(jìn)行讀寫和修改的能力,隔離性可以防止多個(gè)事務(wù)并發(fā)執(zhí)行時(shí)由于交叉執(zhí)行而導(dǎo)致數(shù)據(jù)的不一致。事務(wù)隔離分為不同級(jí)別,包括讀取未提交內(nèi)容,讀取提交內(nèi)容,可重復(fù)讀和可串行化
持久化:事務(wù)處理結(jié)束后,對(duì)數(shù)據(jù)的修改就是永久的,即便系統(tǒng)故障也不會(huì)丟失
在MySQL命令行的默認(rèn)是設(shè)置下,事務(wù)都是自動(dòng)提交的,即執(zhí)行SQL語(yǔ)句后就會(huì)馬上執(zhí)行COMMIT操作。因此要顯式的開啟一個(gè)事務(wù)需要使用命令BEGIN或START TRANSACTION,或者執(zhí)行命令SET AUTOCOMMIT=0,用來(lái)禁止使用當(dāng)前繪畫的自動(dòng)提交
BEGIN或START TRANSACTION;顯式地開啟一個(gè)事務(wù)
COMMIT;也可以使用COMMIT WORK,二者等價(jià)的。COMMIT會(huì)提交事務(wù),并使已對(duì)數(shù)據(jù)庫(kù)進(jìn)行的所有修改成為永久性
ROLLBACK;也可以使用ROLLBACK WORK,二者等價(jià)。回滾會(huì)結(jié)束用戶的事務(wù),并撤回正在進(jìn)行的所有未提交的修改
SAVEPOINT identifier;SAVEPOINT允許在事務(wù)中創(chuàng)建一個(gè)保存點(diǎn),一個(gè)事務(wù)可以有多個(gè)SAVEPOINT
RELESE SAVEPOINT identifier;刪除一個(gè)事務(wù)的保存點(diǎn),當(dāng)沒有指定的保存點(diǎn)時(shí),執(zhí)行該語(yǔ)句會(huì)拋出一個(gè)異常
ROLLBACK TO identified;把事務(wù)回滾到標(biāo)記點(diǎn)
SET TRANSACTION;用來(lái)設(shè)置事務(wù)的隔離級(jí)別。InnoDB存儲(chǔ)引擎提供事務(wù)隔離級(jí)別有READ UNCOMMITTED,READ COMMITTED,REPEATABLE READ和SERIALIZABLE
用BEGIN,ROLLBACK,COMMIT來(lái)實(shí)現(xiàn)
BEGIN開始一個(gè)事務(wù)
ROLLBACK事務(wù)回滾
COMMIT事務(wù)確認(rèn)
直接SET來(lái)改變MySQL的自動(dòng)提交模式:
SET AUTOCOMMIT=0禁止自動(dòng)提交
SET AUTOCOMMIT=1開啟自動(dòng)提交
事務(wù)A跟事務(wù)B之間具有一定的隔離性
read uncommited 讀未提交
在該隔離級(jí)別,所有事務(wù)都可以看到其他未提交事務(wù)的執(zhí)行結(jié)果。本隔離級(jí)別很少用于實(shí)際應(yīng)用。讀取未提交的數(shù)據(jù)稱為臟數(shù)據(jù)
read COMMIT
大多數(shù)數(shù)據(jù)庫(kù)系統(tǒng)的默認(rèn)隔離級(jí)別(但不是MySQL)。一個(gè)事務(wù)只能看見已經(jīng)提交事務(wù)所作的改變。其避免了臟讀,但仍然存在不可重復(fù)讀和幻讀問題
repeatable read
MySQL的默認(rèn)級(jí)別;確保同一事務(wù)的多個(gè)實(shí)例在并發(fā)讀取數(shù)據(jù)時(shí),會(huì)看到同樣的數(shù)據(jù)行。避免了臟讀和不可重復(fù)讀,但是會(huì)導(dǎo)致另一個(gè)問題:幻讀?;米x是指用戶讀取某一個(gè)范圍的數(shù)據(jù)行時(shí),另一個(gè)事務(wù)又在該范圍插入了新行,當(dāng)用戶再讀取該范圍的數(shù)據(jù)行時(shí),會(huì)發(fā)現(xiàn)新的幻影行。InnoDB和Falcon存儲(chǔ)引擎通過多版本并發(fā)控制(MVCC)機(jī)制解決了該問題
可重復(fù)讀的隔離級(jí)別下使用了MVCC機(jī)制,select操作不會(huì)更新版本號(hào),是快照讀(歷史版本);insert,update和delete會(huì)更新版本號(hào),是當(dāng)前讀(當(dāng)前版本)
serializable
最高隔離級(jí)別,通過強(qiáng)制事務(wù)排序,使之不可能相互沖突,從而解決幻讀問題。簡(jiǎn)言之,它是在每個(gè)讀的數(shù)據(jù)行上加上共享鎖。在這個(gè)級(jí)別,可能導(dǎo)致大量的超時(shí)現(xiàn)象和鎖競(jìng)爭(zhēng)
在my.cnf文件設(shè)置
- READ-UNCOMMITTED - READ-COMMITED - REPEATABLE-READ - SERIALIZABLE * 例如 [mysqlId] transaction-isolation = READ-COMMITTED
通過命令動(dòng)態(tài)設(shè)置隔離級(jí)別
SET [GLOBAL|SESSION] TRANSACTION ISOLATION LEVEL <isolation-level> 其中isolation-level可以是: - READ UNCOMMITTED - READ COMMITTED - REPEATABLE READ - SERIALIZABLE GLOBAL|SESSION表示事務(wù)隔離級(jí)別的作用范圍: GLOBAL:表示對(duì)所有會(huì)話有效 SESSION:表示對(duì)當(dāng)前會(huì)話有效
臟讀:事務(wù)A讀取了事務(wù)B更新的數(shù)據(jù),然后B回滾操作,那么A讀取到的數(shù)據(jù)是臟數(shù)據(jù)
不可重復(fù)讀:事務(wù)A多次讀取到同一數(shù)據(jù),事務(wù)B在事務(wù)A多次讀取過程中,對(duì)數(shù)據(jù)做了更新并未提交,導(dǎo)致事務(wù)A多次讀取同一條數(shù)據(jù),結(jié)果不一致
幻讀:前后讀取的結(jié)果數(shù)據(jù)條數(shù)不一致。這是因?yàn)槭聞?wù)A的多次讀取過程中,事務(wù)B對(duì)表進(jìn)行插入或刪除操作
關(guān)于MySQL事務(wù)是什么就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,可以學(xué)到更多知識(shí)。如果覺得文章不錯(cuò),可以把它分享出去讓更多的人看到。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。