1. ISOLATION_DEFAULT: 這是一個 PlatfromTransactionManager 預設的隔離級别,使用資料庫預設的事務隔離級别.
另外四個與 JDBC的隔離級别相對應:
2. ISOLATION_READ_UNCOMMITTED: 這是事務最低的隔離級别,它允許令外一個事務可以看到這個事務未送出的資料,
這種隔離級别會産生髒讀,不可重複讀和幻像讀。
3. ISOLATION_READ_COMMITTED: 保證一個事務修改的資料送出後才能被另外一個事務讀取。另外一個事務不能讀取該事務未送出的資料
4. ISOLATION_REPEATABLE_READ: 這種事務隔離級别可以防止髒讀,不可重複讀。但是可能出現幻像讀。它除了保證一個事務不能讀取另一個事務未送出的資料外,還保證了避免下面的情況産生(不可重複讀)。
5. ISOLATION_SERIALIZABLE 這是花費最高代價但是最可靠的事務隔離級别。事務被處理為順序執行。
除了防止髒讀,不可重複讀外,還避免了幻像讀。
其中的一些概念的說明:
髒讀: 指當一個事務正在通路資料,并且對資料進行了修改,而這種修改還沒有送出到資料庫中,這時,另外一個事務也通路這個資料,然後使用了這個資料。因為這個資料是還沒有送出的資料, 那麼另外一 個事務讀到的這個資料是髒資料,依據髒資料所做的操作可能是不正确的。
不可重複讀: 指在一個事務内,多次讀同一資料。在這個事務還沒有結束時,另外一個事務也通路該同一資料。 那麼,在第一個事務中的兩次讀資料之間,由于第二個事務的修改,那麼第一個事務兩次讀到的資料可能是不一樣的。這樣就發生了在一個事務内兩次讀到的資料是不一樣的,是以稱為是不可重複讀。
幻覺讀:指當事務不是獨立執行時發生的一種現象,例如第一個事務對一個表中的資料進行了修改,這種修改涉及 到表中的全部資料行。同時,第二個事務也修改這個表中的資料,這種修改是向表中插入一行新資料。那麼,就會發生操作第一個事務的使用者發現表中還有 沒有修改的資料行,也就是說幻像讀是指同一查詢在同一事務中多次進行,由于其他送出事務所做的插入操作,每次傳回不同的結果集,此時發生幻像讀,就好象發生了幻覺一樣。