你理解MySQL中的事務(wù)嗎-創(chuàng)新互聯(lián)

本文主要給大家介紹MySQL中的事務(wù),文章內(nèi)容都是筆者用心摘選和編輯的,具有一定的針對性,對大家的參考意義還是比較大的,下面跟筆者一起了解下MySQL中的事務(wù)吧。

創(chuàng)新互聯(lián)建站憑借在網(wǎng)站建設(shè)、網(wǎng)站推廣領(lǐng)域領(lǐng)先的技術(shù)能力和多年的行業(yè)經(jīng)驗,為客戶提供超值的營銷型網(wǎng)站建設(shè)服務(wù),我們始終認為:好的營銷型網(wǎng)站就是好的業(yè)務(wù)員。我們已成功為企業(yè)單位、個人等客戶提供了成都網(wǎng)站設(shè)計、成都網(wǎng)站建設(shè)服務(wù),以良好的商業(yè)信譽,完善的服務(wù)及深厚的技術(shù)力量處于同行領(lǐng)先地位。

一個示例:

銀行引用是事務(wù)的一個經(jīng)典例子:假如銀行有兩張表,一張支票表,一張儲蓄表,現(xiàn)在需要從Jones用戶的支票賬戶轉(zhuǎn)移200¥ 至儲蓄賬戶,那么至少需要三步:

    1. 檢查Jones的支票賬戶余額是否大于200¥

    2. Jones的支票賬戶-200¥

    3. Jones的儲蓄賬戶+200¥

上述三步可組成一個事務(wù),當(dāng)2、3步故障時,之前執(zhí)行的操作會自動回滾,保證數(shù)據(jù)的一致性。

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

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

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

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

一般來說,事務(wù)是必須滿足4個條件(ACID)::原子性(Atomicity,或稱不可分割性)、一致性(Consistency)、隔離性(Isolation,又稱獨立性)、持久性(Durability)。

原子性:一個事務(wù)(transaction)中的所有操作,要么全部完成,要么全部不完成,不會結(jié)束在中間某個環(huán)節(jié)。事務(wù)在執(zhí)行過程中發(fā)生錯誤,會被回滾(Rollback)到事務(wù)開始前的狀態(tài),就像這個事務(wù)從來沒有執(zhí)行過一樣。

一致性:在事務(wù)開始之前和事務(wù)結(jié)束以后,數(shù)據(jù)庫的完整性沒有被破壞。這表示寫入的資料必須完全符合所有的預(yù)設(shè)規(guī)則,這包含資料的精確度、串聯(lián)性以及后續(xù)數(shù)據(jù)庫可以自發(fā)性地完成預(yù)定的工作。

隔離性:數(shù)據(jù)庫允許多個并發(fā)事務(wù)同時對其數(shù)據(jù)進行讀寫和修改的能力,隔離性可以防止多個事務(wù)并發(fā)執(zhí)行時由于交叉執(zhí)行而導(dǎo)致數(shù)據(jù)的不一致。事務(wù)隔離分為不同級別,包括讀未提交(Read uncommitted)、讀提交(read committed)、可重復(fù)讀(repeatable read)和串行化(Serializable)。

持久性:事務(wù)處理結(jié)束后,對數(shù)據(jù)的修改就是永久的,即便系統(tǒng)故障也不會丟失。

注意:在 MySQL 命令行的默認設(shè)置下,事務(wù)都是自動提交的,即執(zhí)行 SQL 語句后就會馬上執(zhí)行 COMMIT 操作。因此要顯式地開啟一個事務(wù)務(wù)須使用命令 BEGIN 或 START TRANSACTION,或者執(zhí)行命令 SET AUTOCOMMIT=0,用來禁止使用當(dāng)前會話的自動提交。

事務(wù)控制語句:

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

COMMIT;也可以使用COMMIT WORK,不過二者是等價的。COMMIT會提交事務(wù),并使已對數(shù)據(jù)庫進行的所有修改成為永久性的;

ROLLBACK;有可以使用ROLLBACK WORK,不過二者是等價的。回滾會結(jié)束用戶的事務(wù),并撤銷正在進行的所有未提交的修改;

SAVEPOINT identifier;SAVEPOINT允許在事務(wù)中創(chuàng)建一個保存點,一個事務(wù)中可以有多個SAVEPOINT;

RELEASE SAVEPOINT identifier;刪除一個事務(wù)的保存點,當(dāng)沒有指定的保存點時,執(zhí)行該語句會拋出一個異常;

ROLLBACK TO identifier;把事務(wù)回滾到標記點;

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

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

1、用 BEGIN, ROLLBACK, COMMIT來實現(xiàn)

START   TRANSACTION       #開啟事務(wù)

ROLLBACK        #回滾事務(wù)

COMMIT             #提交事務(wù)

SAVEPOINT identifier          #事務(wù)語句過多時,可以創(chuàng)建一個保存點,單獨還原至此點

ROLLBACK [WORK] TO [SAVEPOINT] identifier        #還原事務(wù)至此點

RELEASE SAVEPOINT identifier                                 #刪除保存點2、

2、直接用 SET 來改變 MySQL 的自動提交模式:

SET AUTOCOMMIT=0 禁止自動提交

SET AUTOCOMMIT=1 開啟自動提交

隔離級別:

    1. READ UNCOMMITTED (讀未提交)

    2. READ COMMITTED(讀提交)

    3. REPEATEABLE READ(可重復(fù)讀)

    4. SERIALIZABLE(序列化)

各個隔離級別可能產(chǎn)生的問題:

a.臟讀,當(dāng)前線程事務(wù)可以讀取另一個線程事務(wù)未提交修改的數(shù)據(jù)。

b.不可重復(fù)讀,事務(wù)提交前看到的數(shù)據(jù)不一致(別的線程修改提交); 線程1開啟事務(wù)查詢數(shù)據(jù)一個樣,當(dāng)線程2開啟事務(wù)修改提交后,線程1再次查詢發(fā)現(xiàn)數(shù)據(jù)修改(未提交),這就是不可重復(fù)讀。

c.幻讀, 可重復(fù)讀級別通過MVCC機制保證事務(wù)提交前看到的數(shù)據(jù)都是一致的,但是又有一個新問題,當(dāng)線程2修改完數(shù)據(jù)提交后,線程1看到的還是未修改前的原始數(shù)據(jù),但實際底層數(shù)據(jù)已被更改,當(dāng)線程1提交后發(fā)現(xiàn)數(shù)據(jù)改變,像幻覺一樣,這就是幻讀。

d.加鎖讀,SERIABLIZEBLE 為了解決幻讀問題,當(dāng)線程事務(wù)1查詢數(shù)據(jù),線程事務(wù)2修改數(shù)據(jù)會被鎖住,因為數(shù)據(jù)具有不確定性。

看完以上關(guān)于MySQL中的事務(wù),很多讀者朋友肯定多少有一定的了解,如需獲取更多的行業(yè)知識信息 ,可以持續(xù)關(guān)注我們的行業(yè)資訊欄目的。

另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)cdcxhl.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機、免備案服務(wù)器”等云主機租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。

網(wǎng)頁題目:你理解MySQL中的事務(wù)嗎-創(chuàng)新互聯(lián)
網(wǎng)頁路徑:http://bm7419.com/article4/goooe.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供品牌網(wǎng)站建設(shè)、企業(yè)建站電子商務(wù)、服務(wù)器托管商城網(wǎng)站、外貿(mào)網(wǎng)站建設(shè)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

成都網(wǎng)頁設(shè)計公司