mysql中有沒(méi)有事務(wù)?

mysql中有事務(wù),但只有使用了Innodb數(shù)據(jù)庫(kù)引擎的數(shù)據(jù)庫(kù)或表才支持事務(wù)。事務(wù)處理可以用來(lái)維護(hù)數(shù)據(jù)庫(kù)的完整性,它把所有的命令作為一個(gè)整體一起向系統(tǒng)提交或撤銷操作請(qǐng)求,即這一組數(shù)據(jù)庫(kù)命令要么都執(zhí)行,要么都不執(zhí)行。

mysql中有沒(méi)有事務(wù)?

(推薦教程:mysql視頻教程

數(shù)據(jù)庫(kù)的事務(wù)(Transaction)是一種機(jī)制、一個(gè)操作序列,包含了一組數(shù)據(jù)庫(kù)操作命令。事務(wù)把所有的命令作為一個(gè)整體一起向系統(tǒng)提交或撤銷操作請(qǐng)求,即這一組數(shù)據(jù)庫(kù)命令要么都執(zhí)行,要么都不執(zhí)行,因此事務(wù)是一個(gè)不可分割的工作邏輯單元。

在數(shù)據(jù)庫(kù)系統(tǒng)上執(zhí)行并發(fā)操作時(shí),事務(wù)是作為最小的控制單元來(lái)使用的,特別適用于多用戶同時(shí)操作的數(shù)據(jù)庫(kù)系統(tǒng)。例如,航空公司的訂票系統(tǒng)、銀行、保險(xiǎn)公司以及證券交易系統(tǒng)等。

  • 在 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ǔ)句

事務(wù)具有 4 個(gè)特性,即原子性(Atomicity)、一致性(Consistency)、隔離性(Isolation)和持久性(Durability),這 4 個(gè)特性通常簡(jiǎn)稱為 ACID。

1. 原子性

事務(wù)是一個(gè)完整的操作。事務(wù)的各元素是不可分的(原子的)。事務(wù)中的所有元素必須作為一個(gè)整體提交或回滾。如果事務(wù)中的任何元素失敗,則整個(gè)事務(wù)將失敗。

以銀行轉(zhuǎn)賬事務(wù)為例,如果該事務(wù)提交了,則這兩個(gè)賬戶的數(shù)據(jù)將會(huì)更新。如果由于某種原因,事務(wù)在成功更新這兩個(gè)賬戶之前終止了,則不會(huì)更新這兩個(gè)賬戶的余額,并且會(huì)撤銷對(duì)任何賬戶余額的修改,事務(wù)不能部分提交。

2. 一致性

當(dāng)事務(wù)完成時(shí),數(shù)據(jù)必須處于一致?tīng)顟B(tài)。也就是說(shuō),在事務(wù)開(kāi)始之前,數(shù)據(jù)庫(kù)中存儲(chǔ)的數(shù)據(jù)處于一致?tīng)顟B(tài)。在正在進(jìn)行的事務(wù)中. 數(shù)據(jù)可能處于不一致的狀態(tài),如數(shù)據(jù)可能有部分被修改。然而,當(dāng)事務(wù)成功完成時(shí),數(shù)據(jù)必須再次回到已知的一致?tīng)顟B(tài)。通過(guò)事務(wù)對(duì)數(shù)據(jù)所做的修改不能損壞數(shù)據(jù),或者說(shuō)事務(wù)不能使數(shù)據(jù)存儲(chǔ)處于不穩(wěn)定的狀態(tài)。

以銀行轉(zhuǎn)賬事務(wù)事務(wù)為例。在事務(wù)開(kāi)始之前,所有賬戶余額的總額處于一致?tīng)顟B(tài)。在事務(wù)進(jìn)行的過(guò)程中,一個(gè)賬戶余額減少了,而另一個(gè)賬戶余額尚未修改。因此,所有賬戶余額的總額處于不一致?tīng)顟B(tài)。事務(wù)完成以后,賬戶余額的總額再次恢復(fù)到一致?tīng)顟B(tài)。

3. 隔離性

對(duì)數(shù)據(jù)進(jìn)行修改的所有并發(fā)事務(wù)是彼此隔離的,這表明事務(wù)必須是獨(dú)立的,它不應(yīng)以任何方式依賴于或影響其他事務(wù)。修改數(shù)據(jù)的事務(wù)可以在另一個(gè)使用相同數(shù)據(jù)的事務(wù)開(kāi)始之前訪問(wèn)這些數(shù)據(jù),或者在另一個(gè)使用相同數(shù)據(jù)的事務(wù)結(jié)束之后訪問(wèn)這些數(shù)據(jù)。

另外,當(dāng)事務(wù)修改數(shù)據(jù)時(shí),如果任何其他進(jìn)程正在同時(shí)使用相同的數(shù)據(jù),則直到該事務(wù)成功提交之后,對(duì)數(shù)據(jù)的修改才能生效。張三和李四之間的轉(zhuǎn)賬與王五和趙二之間的轉(zhuǎn)賬,永遠(yuǎn)是相互獨(dú)立的。

4. 持久性

事務(wù)的持久性指不管系統(tǒng)是否發(fā)生了故障,事務(wù)處理的結(jié)果都是永久的。

一個(gè)事務(wù)成功完成之后,它對(duì)數(shù)據(jù)庫(kù)所作的改變是永久性的,即使系統(tǒng)出現(xiàn)故障也是如此。也就是說(shuō),一旦事務(wù)被提交,事務(wù)對(duì)數(shù)據(jù)所做的任何變動(dòng)都會(huì)被永久地保留在數(shù)據(jù)庫(kù)中。

事務(wù)的 ACID 原則保證了一個(gè)事務(wù)或者成功提交,或者失敗回滾,二者必居其一。因此,它對(duì)事務(wù)的修改具有可恢復(fù)性。即當(dāng)事務(wù)失敗時(shí),它對(duì)數(shù)據(jù)的修改都會(huì)恢復(fù)到該事務(wù)執(zhí)行前的狀態(tài)。

以上就是

? 版權(quán)聲明
THE END
喜歡就支持一下吧
點(diǎn)贊8 分享