事務的概念 四大特性 隔離級別

2021-08-21 14:12:37 字數 2310 閱讀 3517

首先,說說什麼事務(transaction)

事物就是乙隻運算元據庫的動作集合 處理步驟要麼全部成功 要麼全部失敗 如果一步一步都執行完成 我們稱之為失誤已提交 如果中間有一步執行失敗 失誤必須被回滾

資料庫事務的隔離級別有4種,由低到高分別為read uncommitted 、read committed 、repeatable read 、serializable 。而且,在事務的

併發操作中可能會出現髒讀,不可重複讀,幻讀。下面通過事例一一闡述它們的概念與聯絡。

√: 可能出現    ×: 不會出現

髒讀不可重複讀

幻讀read uncommitted√√

√read committed×√

√repeatable read××

√serializable××

×事務的特性: 

1.原子性 

事務是資料庫邏輯的工作單元,事務包括的所有操作,要麼都做,要麼都不做。 

2.一致性 

事務執行的結果是使資料庫從乙個一致性狀態變成另乙個一致性狀態。一致性與原子性是密切相關的。 

3.隔離性 

乙個事務的執行不能被其他事務干擾。 

4.永續性 

乙個事務一旦提交,它對資料庫中資料的改變應該是永久性的。

事務的隔離級別: 

資料庫事務的隔離級別有四種:從低到高依次為: 

read uncommit(讀,未提交) 

read commit(讀,提交) 

repeatable read(重複讀) 

serializable(序列化) 

四個級別逐個解決了髒讀,不可重複讀,幻讀這積累問題。

注意:我們討論隔離級別的場景,主要是在多個事務併發 的情況下,因此,接下來的講解都圍繞事務併發。

read uncommitted 讀未提交

公司發工資了,領導把5000元打到singo的賬號上,但是該事務並未提交,而singo正好去檢視賬戶,發現工資已經到賬,是5000元整,非常高 興。可是不幸的是,領導發現發給singo的工資金額不對,是2000元,於是迅速回滾了事務,修改金額後,將事務提交,最後singo實際的工資只有 2000元,singo空歡喜一場。

出現上述情況,即我們所說的髒讀 ,兩個併發的事務,「事務a:領導給singo發工資」、「事務b:singo查詢工資賬戶」,事務b讀取了事務a尚未提交的資料。

當隔離級別設定為read uncommitted 時,就可能出現髒讀,如何避免髒讀,請看下乙個隔離級別。

read committed 讀提交

singo拿著工資卡去消費,系統讀取到卡里確實有2000元,而此時她的老婆也正好在網上轉賬,把singo工資卡的2000元轉到另一賬戶,並在 singo之前提交了事務,當singo扣款時,系統檢查到singo的工資卡已經沒有錢,扣款失敗,singo十分納悶,明明卡里有錢,為 何......

出現上述情況,即我們所說的不可重複讀 ,兩個併發的事務,「事務a:singo消費」、「事務b:singo的老婆網上轉賬」,事務a事先讀取了資料,事務b緊接了更新了資料,並提交了事務,而事務a再次讀取該資料時,資料已經發生了改變。

當隔離級別設定為read committed 時,避免了髒讀,但是可能會造成不可重複讀。

大多數資料庫的預設級別就是read committed,比如sql server , oracle。如何解決不可重複讀這一問題,請看下乙個隔離級別。

repeatable read 重複讀

當隔離級別設定為repeatable read 時,可以避免不可重複讀。當singo拿著工資卡去消費時,一旦系統開始讀取工資卡資訊(即事務開始),singo的老婆就不可能對該記錄進行修改,也就是singo的老婆不能在此時轉賬。

雖然repeatable read避免了不可重複讀,但還有可能出現幻讀 。

singo的老婆工作在銀行部門,她時常通過銀行內部系統檢視singo的信用卡消費記錄。有一天,她正在查詢到singo當月信用卡的總消費金額 (select sum(amount) from transaction where month = 本月)為80元,而singo此時正好在外面胡吃海塞後在收銀台買單,消費1000元,即新增了一條1000元的消費記錄(insert transaction ... ),並提交了事務,隨後singo的老婆將singo當月信用卡消費的明細列印到a4紙上,卻發現消費總額為1080元,singo的老婆很詫異,以為出 現了幻覺,幻讀就這樣產生了。

注:mysql的預設隔離級別就是repeatable read。

serializable 序列化

serializable 是最高的事務隔離級別,同時代價也花費最高,效能很低,一般很少使用,在該級別下,事務順序執行,不僅可以避免髒讀、不可重複讀,還避免了幻像讀。

事務的四大特性和隔離級別

事務,其定義是應用程式中一系列不可分割的操作,就是一組可以完成某個業務的 集合,在關聯式資料庫中,事務可以是一條sql語句,或者一組sql語句,亦或整個程式。其中事務有四個特徵,必須同時滿足這四個特徵才是乙個完整的事務。即事務的acid特性 原子性 atomicity 即事務是資料庫的不可分割單元,...

事務的四大特性及隔離級別

一 事務的作用 事務管理對於企業級應用而言至關重要,它保證了使用者的每一次操作都是可靠的,即便出現了異常的訪問情況,也不至於破壞後台資料的完整性。就像銀行的自動提款機atm,通常atm都可以正常為客戶服務,但是也難免遇到操作過程中及其突然出故障的情況,此時,事務就必須確保出故障前對賬戶的操作不生效,...

事務的四大特性和隔離級別

在資料庫操作中,一項事務 transaction 是由一條或多條運算元據庫的 sql 語句組成的乙個不可分割的工作單元,這些操作要麼都完成,要麼都取消。接下來將圍繞事務的特性 併發問題以及隔離級別進行講解。事務的定義很嚴格,它必須同時滿足四個特性,即原子性 一致性 隔離性和永續性,也就是人們俗稱的 ...