這篇文章將為大家詳細(xì)講解有關(guān)MySQL事務(wù)是什么,小編覺得挺實(shí)用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。
創(chuàng)新互聯(lián)建站專注于企業(yè)營銷型網(wǎng)站建設(shè)、網(wǎng)站重做改版、金鳳網(wǎng)站定制設(shè)計(jì)、自適應(yīng)品牌網(wǎng)站建設(shè)、html5、商城網(wǎng)站建設(shè)、集團(tuán)公司官網(wǎng)建設(shè)、成都外貿(mào)網(wǎng)站制作、高端網(wǎng)站制作、響應(yīng)式網(wǎng)頁設(shè)計(jì)等建站業(yè)務(wù),價(jià)格優(yōu)惠性價(jià)比高,為金鳳等各大城市提供網(wǎng)站開發(fā)制作服務(wù)。MySQL事務(wù)以及事務(wù)隔離級別
MySQL事務(wù)主要用于處理操作量大,復(fù)雜度高的數(shù)據(jù)。比如在人員管理系統(tǒng)中,你刪除一個人員,你就要刪除人員的基本資料,也要刪除和該人員相關(guān)的信息,如信箱,文章等,這些數(shù)據(jù)庫操作語句就構(gòu)成了一個事務(wù)(推薦課程:MySQL教程)
MySQL中只有使用了Innodb數(shù)據(jù)庫引擎的數(shù)據(jù)庫或表才支持事務(wù)
事務(wù)處理可以用來維護(hù)數(shù)據(jù)庫的完整性,保證成批的SQL語句要么全部執(zhí)行,要么全部不執(zhí)行
事務(wù)用來管理insert,update,delete語句
一般來說,事務(wù)必須滿足4個條件:原子性,一致性,隔離性,持久性
原子性:一個事務(wù)中所有操作,要么全部執(zhí)行,要么全部不執(zhí)行不會結(jié)束在中間某個環(huán)節(jié)。事務(wù)在執(zhí)行過程中發(fā)生錯誤會被回滾到事務(wù)開始前的狀態(tài)
一致性:在事務(wù)開始之前和事務(wù)結(jié)束以后,數(shù)據(jù)庫的完整性沒有被破壞。這表示寫入的資料必須完全符合所有的預(yù)設(shè)規(guī)則,包含資料的精確度,串聯(lián)性以及后續(xù)數(shù)據(jù)庫可以自發(fā)性的完成預(yù)定的工作
隔離性:數(shù)據(jù)庫允許多個并發(fā)事務(wù)同時對其數(shù)據(jù)進(jìn)行讀寫和修改的能力,隔離性可以防止多個事務(wù)并發(fā)執(zhí)行時由于交叉執(zhí)行而導(dǎo)致數(shù)據(jù)的不一致。事務(wù)隔離分為不同級別,包括讀取未提交內(nèi)容,讀取提交內(nèi)容,可重復(fù)讀和可串行化
持久化:事務(wù)處理結(jié)束后,對數(shù)據(jù)的修改就是永久的,即便系統(tǒng)故障也不會丟失
在MySQL命令行的默認(rèn)是設(shè)置下,事務(wù)都是自動提交的,即執(zhí)行SQL語句后就會馬上執(zhí)行COMMIT操作。因此要顯式的開啟一個事務(wù)需要使用命令BEGIN或START TRANSACTION,或者執(zhí)行命令SET AUTOCOMMIT=0,用來禁止使用當(dāng)前繪畫的自動提交
BEGIN或START TRANSACTION;顯式地開啟一個事務(wù)
COMMIT;也可以使用COMMIT WORK,二者等價(jià)的。COMMIT會提交事務(wù),并使已對數(shù)據(jù)庫進(jìn)行的所有修改成為永久性
ROLLBACK;也可以使用ROLLBACK WORK,二者等價(jià)。回滾會結(jié)束用戶的事務(wù),并撤回正在進(jìn)行的所有未提交的修改
SAVEPOINT identifier;SAVEPOINT允許在事務(wù)中創(chuàng)建一個保存點(diǎn),一個事務(wù)可以有多個SAVEPOINT
RELESE SAVEPOINT identifier;刪除一個事務(wù)的保存點(diǎn),當(dāng)沒有指定的保存點(diǎn)時,執(zhí)行該語句會拋出一個異常
ROLLBACK TO identified;把事務(wù)回滾到標(biāo)記點(diǎn)
SET TRANSACTION;用來設(shè)置事務(wù)的隔離級別。InnoDB存儲引擎提供事務(wù)隔離級別有READ UNCOMMITTED,READ COMMITTED,REPEATABLE READ和SERIALIZABLE
用BEGIN,ROLLBACK,COMMIT來實(shí)現(xiàn)
BEGIN開始一個事務(wù)
ROLLBACK事務(wù)回滾
COMMIT事務(wù)確認(rèn)
直接SET來改變MySQL的自動提交模式:
SET AUTOCOMMIT=0禁止自動提交
SET AUTOCOMMIT=1開啟自動提交
事務(wù)A跟事務(wù)B之間具有一定的隔離性
read uncommited 讀未提交
在該隔離級別,所有事務(wù)都可以看到其他未提交事務(wù)的執(zhí)行結(jié)果。本隔離級別很少用于實(shí)際應(yīng)用。讀取未提交的數(shù)據(jù)稱為臟數(shù)據(jù)
read COMMIT
大多數(shù)數(shù)據(jù)庫系統(tǒng)的默認(rèn)隔離級別(但不是MySQL)。一個事務(wù)只能看見已經(jīng)提交事務(wù)所作的改變。其避免了臟讀,但仍然存在不可重復(fù)讀和幻讀問題
repeatable read
MySQL的默認(rèn)級別;確保同一事務(wù)的多個實(shí)例在并發(fā)讀取數(shù)據(jù)時,會看到同樣的數(shù)據(jù)行。避免了臟讀和不可重復(fù)讀,但是會導(dǎo)致另一個問題:幻讀?;米x是指用戶讀取某一個范圍的數(shù)據(jù)行時,另一個事務(wù)又在該范圍插入了新行,當(dāng)用戶再讀取該范圍的數(shù)據(jù)行時,會發(fā)現(xiàn)新的幻影行。InnoDB和Falcon存儲引擎通過多版本并發(fā)控制(MVCC)機(jī)制解決了該問題
可重復(fù)讀的隔離級別下使用了MVCC機(jī)制,select操作不會更新版本號,是快照讀(歷史版本);insert,update和delete會更新版本號,是當(dāng)前讀(當(dāng)前版本)
serializable
最高隔離級別,通過強(qiáng)制事務(wù)排序,使之不可能相互沖突,從而解決幻讀問題。簡言之,它是在每個讀的數(shù)據(jù)行上加上共享鎖。在這個級別,可能導(dǎo)致大量的超時現(xiàn)象和鎖競爭
在my.cnf文件設(shè)置
- READ-UNCOMMITTED - READ-COMMITED - REPEATABLE-READ - SERIALIZABLE * 例如 [mysqlId] transaction-isolation = READ-COMMITTED
通過命令動態(tài)設(shè)置隔離級別
SET [GLOBAL|SESSION] TRANSACTION ISOLATION LEVEL <isolation-level> 其中isolation-level可以是: - READ UNCOMMITTED - READ COMMITTED - REPEATABLE READ - SERIALIZABLE GLOBAL|SESSION表示事務(wù)隔離級別的作用范圍: GLOBAL:表示對所有會話有效 SESSION:表示對當(dāng)前會話有效
臟讀:事務(wù)A讀取了事務(wù)B更新的數(shù)據(jù),然后B回滾操作,那么A讀取到的數(shù)據(jù)是臟數(shù)據(jù)
不可重復(fù)讀:事務(wù)A多次讀取到同一數(shù)據(jù),事務(wù)B在事務(wù)A多次讀取過程中,對數(shù)據(jù)做了更新并未提交,導(dǎo)致事務(wù)A多次讀取同一條數(shù)據(jù),結(jié)果不一致
幻讀:前后讀取的結(jié)果數(shù)據(jù)條數(shù)不一致。這是因?yàn)槭聞?wù)A的多次讀取過程中,事務(wù)B對表進(jìn)行插入或刪除操作
關(guān)于MySQL事務(wù)是什么就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,可以學(xué)到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。
名稱欄目:MySQL事務(wù)是什么-創(chuàng)新互聯(lián)
當(dāng)前網(wǎng)址:http://aaarwkj.com/article26/ccdcjg.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供小程序開發(fā)、靜態(tài)網(wǎng)站、手機(jī)網(wǎng)站建設(shè)、虛擬主機(jī)、網(wǎng)站收錄、網(wǎng)站內(nèi)鏈
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容