事務的隔離級別
在資料庫操作中,為了有效保證併發讀取資料的正確性,提出的事務隔離級別。
問題的提出
資料庫是要被廣大客戶所共享訪問的,那麼在資料庫操作過程中很可能出現以下幾種不確定情況。
更新丟失
兩個事務都同時更新一行資料,乙個事務對資料的更新把另乙個事務對資料的更新覆蓋了。這是因為系統沒有執行任何的鎖操作,因此併發事務並沒有被隔離開來。
髒讀乙個事務讀取到了另乙個事務未提交的資料操作結果。這是相當危險的,因為很可能所有的操作都被回滾。
不可重複讀
不可重複讀(non-repeatable reads):乙個事務對同一行資料重複讀取兩次,但是卻得到了不同的結果。
包括以下情況:
(1) 虛讀:事務t1讀取某一資料後,事務t2對其做了修改,當事務t1再次讀該資料時得到與前一次不同的值。
(2) 幻讀(phantom reads):事務在操作過程中進行兩次查詢,第二次查詢的結果包含了第一次查詢中未出現的資料或者缺少了第一次查詢**現的資料(這裡並不要求兩次查詢的sql語句相同)。這是因為在兩次查詢過程中有另外乙個事務插入資料造成的。
解決方案
為了避免上面出現的幾種情況,在標準sql規範中,定義了4個事務隔離級別,不同的隔離級別對事務的處理不同。
未授權讀取
也稱為讀未提交(read uncommitted):允許髒讀取,但不允許更新丟失。如果乙個事務已經開始寫資料,則另外乙個事務則不允許同時進行寫操作,但允許其他事務讀此行資料。該隔離級別可以通過「排他寫鎖」實現。
授權讀取
也稱為讀提交(read committed):允許不可重複讀取,但不允許髒讀取。這可以通過「瞬間共享讀鎖」和「排他寫鎖」實現。讀取資料的事務允許其他事務繼續訪問該行資料,但是未提交的寫事務將會禁止其他事務訪問該行。
可重複讀取(repeatable read)
可重複讀取(repeatable read):禁止不可重複讀取和髒讀取,但是有時可能出現幻讀資料。這可以通過「共享讀鎖」和「排他寫鎖」實現。讀取資料的事務將會禁止寫事務(但允許讀事務),寫事務則禁止任何其他事務。
序列化(serializable)
序列化(serializable):提供嚴格的事務隔離。它要求事務序列化執行,事務只能乙個接著乙個地執行,不能併發執行。僅僅通過「行級鎖」是無法實現事務序列化的,必須通過其他機制保證新插入的資料不會被剛執行查詢操作的事務訪問到。
隔離級別越高,越能保證資料的完整性和一致性,但是對併發效能的影響也越大。對於多數應用程式,可以優先考慮把資料庫系統的隔離級別設為read committed。它能夠避免髒讀取,而且具有較好的併發效能。儘管它會導致不可重複讀、幻讀和第二類丟失更新這些併發問題,在可能出現這類問題的個別場合,可以由應用程式採用悲觀鎖或樂觀鎖來控制。
MySQL事務,事務隔離級別詳解
1 什麼是事務指作為單個邏輯工作單元執行的一系列操作,要麼完全地執行,要麼完全地不執行。2 事務的4個特性原子性 atomicity 一致性 consistency 隔離性 isolation 永續性 durability 3 每個特性的意思 原子性原子性是指事務是乙個不可再分割的工作單位,事務中的...
oracle事務講解 事務隔離級別例項
今天溫習oracle事務,記錄如下 事務定義 事務是保持資料的一致性,它由相關的ddl或者dml語句做為載體,這組語句執行的結果要麼一起成功,要麼一起失敗。我們知道sql92標準定義了資料庫事務的四個特點 2.事務控制命令 3.鎖的概念 鎖是為了保證多個併發的事務在引用同乙個資源時,對資源的保護,同...
MySQL事務隔離級別詳解
sql標準定義了4類隔離級別,包括了一些具體規則,用來限定事務內外的哪些改變是可見的,哪些是不可見的。低階別的隔離級一般支援更高的併發處理,並擁有更低的系統開銷。read uncommitted 讀取未提交內容 在該隔離級別,所有事務都可以看到其他未提交事務的執行結果。本隔離級別很少用於實際應用,因...