MySQL事務(wù)是什么

這篇文章將為大家詳細(xì)講解有關(guān)MySQL事務(wù)是什么,小編覺得挺實(shí)用的,因此分享給大家做個(gè)參考,希望大家閱讀完這篇文章后可以有所收獲。

創(chuàng)新互聯(lián)主營左貢網(wǎng)站建設(shè)的網(wǎng)絡(luò)公司,主營網(wǎng)站建設(shè)方案,成都app開發(fā),左貢h5重慶小程序開發(fā)公司搭建,左貢網(wǎng)站營銷推廣歡迎左貢等地區(qū)企業(yè)咨詢

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

MySQL事務(wù)主要用于處理操作量大,復(fù)雜度高的數(shù)據(jù)。比如在人員管理系統(tǒng)中,你刪除一個(gè)人員,你就要?jiǎng)h除人員的基本資料,也要?jiǎng)h除和該人員相關(guān)的信息,如信箱,文章等,這些數(shù)據(jù)庫操作語句就構(gòu)成了一個(gè)事務(wù)(推薦課程:MySQL教程)

    • MySQL中只有使用了Innodb數(shù)據(jù)庫引擎的數(shù)據(jù)庫或表才支持事務(wù)

    • 事務(wù)處理可以用來維護(hù)數(shù)據(jù)庫的完整性,保證成批的SQL語句要么全部執(zhí)行,要么全部不執(zhí)行

    • 事務(wù)用來管理insert,update,delete語句

  • 一般來說,事務(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ù)庫的完整性沒有被破壞。這表示寫入的資料必須完全符合所有的預(yù)設(shè)規(guī)則,包含資料的精確度,串聯(lián)性以及后續(xù)數(shù)據(jù)庫可以自發(fā)性的完成預(yù)定的工作

    • 隔離性:數(shù)據(jù)庫允許多個(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語句后就會(huì)馬上執(zhí)行COMMIT操作。因此要顯式的開啟一個(gè)事務(wù)需要使用命令BEGIN或START TRANSACTION,或者執(zhí)行命令SET AUTOCOMMIT=0,用來禁止使用當(dāng)前繪畫的自動(dòng)提交

事務(wù)控制語句:

  • BEGIN或START TRANSACTION;顯式地開啟一個(gè)事務(wù)

  • COMMIT;也可以使用COMMIT WORK,二者等價(jià)的。COMMIT會(huì)提交事務(wù),并使已對(duì)數(shù)據(jù)庫進(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í)行該語句會(huì)拋出一個(gè)異常

  • ROLLBACK TO identified;把事務(wù)回滾到標(biāo)記點(diǎn)

  • SET TRANSACTION;用來設(shè)置事務(wù)的隔離級(jí)別。InnoDB存儲(chǔ)引擎提供事務(wù)隔離級(jí)別有READ UNCOMMITTED,READ COMMITTED,REPEATABLE READ和SERIALIZABLE

MySQL事務(wù)處理主要有兩種方法:

  1. 用BEGIN,ROLLBACK,COMMIT來實(shí)現(xiàn)

    • BEGIN開始一個(gè)事務(wù)

    • ROLLBACK事務(wù)回滾

    • COMMIT事務(wù)確認(rèn)

  2. 直接SET來改變MySQL的自動(dòng)提交模式:

    • SET AUTOCOMMIT=0禁止自動(dòng)提交

    • SET AUTOCOMMIT=1開啟自動(dòng)提交

事務(wù)四大特性之一:隔離性

  1. 事務(wù)A跟事務(wù)B之間具有一定的隔離性

  2. read uncommited 讀未提交

    • 在該隔離級(jí)別,所有事務(wù)都可以看到其他未提交事務(wù)的執(zhí)行結(jié)果。本隔離級(jí)別很少用于實(shí)際應(yīng)用。讀取未提交的數(shù)據(jù)稱為臟數(shù)據(jù)

  3. read COMMIT

    • 大多數(shù)數(shù)據(jù)庫系統(tǒng)的默認(rèn)隔離級(jí)別(但不是MySQL)。一個(gè)事務(wù)只能看見已經(jīng)提交事務(wù)所作的改變。其避免了臟讀,但仍然存在不可重復(fù)讀和幻讀問題

  4. 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)前版本)

  5. serializable

    • 最高隔離級(jí)別,通過強(qiáng)制事務(wù)排序,使之不可能相互沖突,從而解決幻讀問題。簡(jiǎn)言之,它是在每個(gè)讀的數(shù)據(jù)行上加上共享鎖。在這個(gè)級(jí)別,可能導(dǎo)致大量的超時(shí)現(xiàn)象和鎖競(jìng)爭(zhēng)

設(shè)置事務(wù)隔離級(jí)別

  1. 在my.cnf文件設(shè)置

- READ-UNCOMMITTED
- READ-COMMITED
- REPEATABLE-READ
- SERIALIZABLE
* 例如
[mysqlId]
transaction-isolation = READ-COMMITTED
  1. 通過命令動(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ù)并發(fā)問題

  1. 臟讀:事務(wù)A讀取了事務(wù)B更新的數(shù)據(jù),然后B回滾操作,那么A讀取到的數(shù)據(jù)是臟數(shù)據(jù)

  2. 不可重復(fù)讀:事務(wù)A多次讀取到同一數(shù)據(jù),事務(wù)B在事務(wù)A多次讀取過程中,對(duì)數(shù)據(jù)做了更新并未提交,導(dǎo)致事務(wù)A多次讀取同一條數(shù)據(jù),結(jié)果不一致

  3. 幻讀:前后讀取的結(jié)果數(shù)據(jù)條數(shù)不一致。這是因?yàn)槭聞?wù)A的多次讀取過程中,事務(wù)B對(duì)表進(jìn)行插入或刪除操作

關(guān)于MySQL事務(wù)是什么就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,可以學(xué)到更多知識(shí)。如果覺得文章不錯(cuò),可以把它分享出去讓更多的人看到。

新聞名稱:MySQL事務(wù)是什么
鏈接URL:http://muchs.cn/article26/gppejg.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供品牌網(wǎng)站建設(shè)、關(guān)鍵詞優(yōu)化商城網(wǎng)站、網(wǎng)站建設(shè)、小程序開發(fā)、網(wǎng)站設(shè)計(jì)公司

廣告

聲明:本網(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í)需注明來源: 創(chuàng)新互聯(lián)

h5響應(yīng)式網(wǎng)站建設(shè)