這篇文章主要介紹了MySQL中有事務(wù)嗎,具有一定借鑒價(jià)值,需要的朋友可以參考下。希望大家閱讀完這篇文章后大有收獲。下面讓小編帶著大家一起了解一下。
創(chuàng)新互聯(lián)服務(wù)項(xiàng)目包括通河網(wǎng)站建設(shè)、通河網(wǎng)站制作、通河網(wǎng)頁制作以及通河網(wǎng)絡(luò)營銷策劃等。多年來,我們專注于互聯(lián)網(wǎng)行業(yè),利用自身積累的技術(shù)優(yōu)勢、行業(yè)經(jīng)驗(yàn)、深度合作伙伴關(guān)系等,向廣大中小型企業(yè)、政府機(jī)構(gòu)等提供互聯(lián)網(wǎng)行業(yè)的解決方案,通河網(wǎng)站推廣取得了明顯的社會(huì)效益與經(jīng)濟(jì)效益。目前,我們服務(wù)的客戶以成都為中心已經(jīng)輻射到通河省份的部分城市,未來相信會(huì)繼續(xù)擴(kuò)大服務(wù)區(qū)域并繼續(xù)獲得客戶的支持與信任!
mysql中有事務(wù),但只有使用了Innodb數(shù)據(jù)庫引擎的數(shù)據(jù)庫或表才支持事務(wù)。事務(wù)處理可以用來維護(hù)數(shù)據(jù)庫的完整性,它把所有的命令作為一個(gè)整體一起向系統(tǒng)提交或撤銷操作請求,即這一組數(shù)據(jù)庫命令要么都執(zhí)行,要么都不執(zhí)行。
數(shù)據(jù)庫的事務(wù)(Transaction)是一種機(jī)制、一個(gè)操作序列,包含了一組數(shù)據(jù)庫操作命令。事務(wù)把所有的命令作為一個(gè)整體一起向系統(tǒng)提交或撤銷操作請求,即這一組數(shù)據(jù)庫命令要么都執(zhí)行,要么都不執(zhí)行,因此事務(wù)是一個(gè)不可分割的工作邏輯單元。
在數(shù)據(jù)庫系統(tǒng)上執(zhí)行并發(fā)操作時(shí),事務(wù)是作為最小的控制單元來使用的,特別適用于多用戶同時(shí)操作的數(shù)據(jù)庫系統(tǒng)。例如,航空公司的訂票系統(tǒng)、銀行、保險(xiǎn)公司以及證券交易系統(tǒng)等。
在 MySQL 中只有使用了 Innodb 數(shù)據(jù)庫引擎的數(shù)據(jù)庫或表才支持事務(wù)。
事務(wù)處理可以用來維護(hù)數(shù)據(jù)庫的完整性,保證成批的 SQL 語句要么全部執(zhí)行,要么全部不執(zhí)行。
事務(wù)用來管理 insert,update,delete 語句
事務(wù)具有 4 個(gè)特性,即原子性(Atomicity)、一致性(Consistency)、隔離性(Isolation)和持久性(Durability),這 4 個(gè)特性通常簡稱為 ACID。
1. 原子性
事務(wù)是一個(gè)完整的操作。事務(wù)的各元素是不可分的(原子的)。事務(wù)中的所有元素必須作為一個(gè)整體提交或回滾。如果事務(wù)中的任何元素失敗,則整個(gè)事務(wù)將失敗。
以銀行轉(zhuǎn)賬事務(wù)為例,如果該事務(wù)提交了,則這兩個(gè)賬戶的數(shù)據(jù)將會(huì)更新。如果由于某種原因,事務(wù)在成功更新這兩個(gè)賬戶之前終止了,則不會(huì)更新這兩個(gè)賬戶的余額,并且會(huì)撤銷對任何賬戶余額的修改,事務(wù)不能部分提交。
2. 一致性
當(dāng)事務(wù)完成時(shí),數(shù)據(jù)必須處于一致狀態(tài)。也就是說,在事務(wù)開始之前,數(shù)據(jù)庫中存儲(chǔ)的數(shù)據(jù)處于一致狀態(tài)。在正在進(jìn)行的事務(wù)中. 數(shù)據(jù)可能處于不一致的狀態(tài),如數(shù)據(jù)可能有部分被修改。然而,當(dāng)事務(wù)成功完成時(shí),數(shù)據(jù)必須再次回到已知的一致狀態(tài)。通過事務(wù)對數(shù)據(jù)所做的修改不能損壞數(shù)據(jù),或者說事務(wù)不能使數(shù)據(jù)存儲(chǔ)處于不穩(wěn)定的狀態(tài)。
以銀行轉(zhuǎn)賬事務(wù)事務(wù)為例。在事務(wù)開始之前,所有賬戶余額的總額處于一致狀態(tài)。在事務(wù)進(jìn)行的過程中,一個(gè)賬戶余額減少了,而另一個(gè)賬戶余額尚未修改。因此,所有賬戶余額的總額處于不一致狀態(tài)。事務(wù)完成以后,賬戶余額的總額再次恢復(fù)到一致狀態(tài)。
3. 隔離性
對數(shù)據(jù)進(jìn)行修改的所有并發(fā)事務(wù)是彼此隔離的,這表明事務(wù)必須是獨(dú)立的,它不應(yīng)以任何方式依賴于或影響其他事務(wù)。修改數(shù)據(jù)的事務(wù)可以在另一個(gè)使用相同數(shù)據(jù)的事務(wù)開始之前訪問這些數(shù)據(jù),或者在另一個(gè)使用相同數(shù)據(jù)的事務(wù)結(jié)束之后訪問這些數(shù)據(jù)。
另外,當(dāng)事務(wù)修改數(shù)據(jù)時(shí),如果任何其他進(jìn)程正在同時(shí)使用相同的數(shù)據(jù),則直到該事務(wù)成功提交之后,對數(shù)據(jù)的修改才能生效。張三和李四之間的轉(zhuǎn)賬與王五和趙二之間的轉(zhuǎn)賬,永遠(yuǎn)是相互獨(dú)立的。
4. 持久性
事務(wù)的持久性指不管系統(tǒng)是否發(fā)生了故障,事務(wù)處理的結(jié)果都是永久的。
一個(gè)事務(wù)成功完成之后,它對數(shù)據(jù)庫所作的改變是永久性的,即使系統(tǒng)出現(xiàn)故障也是如此。也就是說,一旦事務(wù)被提交,事務(wù)對數(shù)據(jù)所做的任何變動(dòng)都會(huì)被永久地保留在數(shù)據(jù)庫中。
事務(wù)的 ACID 原則保證了一個(gè)事務(wù)或者成功提交,或者失敗回滾,二者必居其一。因此,它對事務(wù)的修改具有可恢復(fù)性。即當(dāng)事務(wù)失敗時(shí),它對數(shù)據(jù)的修改都會(huì)恢復(fù)到該事務(wù)執(zhí)行前的狀態(tài)。
感謝你能夠認(rèn)真閱讀完這篇文章,希望小編分享mysql中有事務(wù)嗎內(nèi)容對大家有幫助,同時(shí)也希望大家多多支持創(chuàng)新互聯(lián),關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,遇到問題就找創(chuàng)新互聯(lián),詳細(xì)的解決方法等著你來學(xué)習(xí)!