1. 程式人生 > >spring的事務隔離級別

spring的事務隔離級別

1. ISOLATION_DEFAULT:

這是一個PlatfromTransactionManager預設的隔離級別,使用資料庫預設的事務隔離級別。

另外四個與JDBC的隔離級別相對應。

 2. ISOLATION_READ_UNCOMMITTED:

這是事務最低的隔離級別,它充許令外一個事務可以看到這個事務未提交的資料。

這種隔離級別會產生髒讀,不可重複讀和幻讀。

 3. ISOLATION_READ_COMMITTED:

保證一個事務修改的資料提交後才能被另外一個事務讀取。另外一個事務不能讀取該事務未提交的資料。

 4. ISOLATION_REPEATABLE_READ:

這種事務隔離級別可以防止髒讀,不可重複讀。但是可能出現幻讀。

它除了保證一個事務不能讀取另一個事務未提交的資料外,還保證了避免下面的情況產生(不可重複讀)。

 5. ISOLATION_SERIALIZABLE

這是花費最高代價但是最可靠的事務隔離級別。事務被處理為順序執行。

除了防止髒讀,不可重複讀外,還避免了幻讀。

名詞解釋:

髒讀: 指當一個事務正在訪問資料,並且對資料進行了修改,而這種修改還沒有提交到資料庫中,這時, 另外一個事務也訪問這個資料,然後使用了這個資料。因為這個資料是還沒有提交的資料, 那麼另外一個事務讀到的這個資料是髒資料,依據髒資料所做的操作可能是不正確的。   

 不可重複讀: 指在一個事務內,多次讀同一資料。在這個事務還沒有結束時,另外一個事務也訪問該同一資料。那麼,在第一個事務中的兩次讀資料之間,由於第二個事務的修改,那麼第一個事務兩次讀到的資料可能是不一樣的。這樣就發生了在一個事務內兩次讀到的資料是不一樣的,因此稱為是不可重複讀。   

場景:update        

 幻讀: 指當事務不是獨立執行時發生的一種現象,例如第一個事務對一個表中的資料進行了修改,這種修改涉及到表中的全部資料行。同時,第二個事務也修改這個表中的資料,這種修改是向表中插入一行新資料。那麼,以後就會發生操作第一個事務的使用者發現表中還有沒有修改的資料行,就好象發生了幻覺一樣。

場景:insert