事務的四大特性ACID

2021-10-20 15:00:13 字數 1309 閱讀 7644

一. 原子性(atomicity)

乙個事務要麼全部提交成功,要麼全部失敗回滾,不能只執行其中的一部分操作,這就是事務的原子性

二. 一致性(consistency)

事務的執行不能破壞資料庫資料的完整性和一致性,乙個事務在執行之前和執行之後,資料庫都必須處於一致性狀態。

如果資料庫系統在執行過程中發生故障,有些事務尚未完成就被迫中斷,這些未完成的事務對資料庫所作的修改有一部分已寫入物理資料庫,這是資料庫就處於一種不正確的狀態,也就是不一致的狀態

三. 隔離性(isolation)

事務的隔離性是指在併發環境中,併發的事務時相互隔離的,乙個事務的執行不能不被其他事務干擾。不同的事務併發操作相同的資料時,每個事務都有各自完成的資料空間,即乙個事務內部的操作及使用的資料對其他併發事務時隔離的,併發執行的各個事務之間不能相互干擾。

在標準sql規範中,定義了4個事務隔離級別,不同的隔離級別對事務的處理不同,分別是:未授權讀取,授權讀取,可重複讀取和序列化

1、讀未提交(read uncommited),該隔離級別允許髒讀取,其隔離級別最低;比如事務a和事務b同時進行,事務a在整個執行階段,會將某資料的值從1開始一直加到10,然後進行事務提交,此時,事務b能夠看到這個資料項在事務a操作過程中的所有中間值(如1變成2,2變成3等),而對這一系列的中間值的讀取就是未授權讀取

2、授權讀取也稱為已提交讀(read commited),授權讀取只允許獲取已經提交的資料。比如事務a和事務b同時進行,事務a進行+1操作,此時,事務b無法看到這個資料項在事務a操作過程中的所有中間值,只能看到最終的10。另外,如果說有乙個事務c,和事務a進行非常類似的操作,只是事務c是將資料項從10加到20,此時事務b也同樣可以讀取到20,即授權讀取允許不可重複讀取。

3、可重複讀(repeatable read)

就是保證在事務處理過程中,多次讀取同乙個資料時,其值都和事務開始時刻是一致的,因此該事務級別禁止不可重複讀取和髒讀取,但是有可能出現幻影資料。所謂幻影資料,就是指同樣的事務操作,在前後兩個時間段內執行對同乙個資料項的讀取,可能出現不一致的結果。在上面的例子中,可重複讀取隔離級別能夠保證事務b在第一次事務操作過程中,始終對資料項讀取到1,但是在下一次事務操作中,即使事務b(注意,事務名字雖然相同,但是指的是另乙個事務操作)採用同樣的查詢方式,就可能讀取到10或20。

4、序列化

是最嚴格的事務隔離級別,它要求所有事務被序列執行,即事務只能乙個接乙個的進行處理,不能併發執行

四.永續性(durability)

一旦事務提交,那麼它對資料庫中的對應資料的狀態的變更就會永久儲存到資料庫中。–即使發生系統崩潰或機器宕機等故障,只要資料庫能夠重新啟動,那麼一定能夠將其恢復到事務成功結束的狀態

事務四大特性(ACID)

1.原子性 atomicity 化學中的原子指不可再分的基本微粒,資料庫中原子性強調事務是乙個不可分割的整體,事務開始後所有操作要麼全部成功,要麼全部失敗,不可能停滯在中間某個環節。如果事務執行過程 錯就會回滾到事務開始前的狀態,所有的操作就像沒有發生一樣不會對資料庫有任何影響。2.一致性 cons...

事務的四大特性(ACID)

原子性 一致性 隔離性 永續性 原子性 事務要麼全部成功,要麼全部回滾,只要有乙個不成功就回滾,一致性 一致性是指事務必須使資料庫從乙個一致性狀態變換到另乙個一致性狀態,也就是說乙個事務執行之前和執行之後都必須處於一致性狀態。如 a有300元,b有500元 一共是800元,a給b轉200,但是他們一...

事務的四大特性 ACID

acid 原子性 一致性 隔離性 永續性 就是一系列的操作,要麼都執行,要麼都不執行。當乙個事務發生異常的時候,就會通過回滾來保證原子性。在mysql中,原子性是通過回滾日誌來實現的,回滾日誌就是我們的操作的逆操作。事務提交之後一定會儲存到資料庫中,如果要回滾只能手動執行相反的操作了 事務的隔離性會...