事務一般是指資料庫事務,是指作為一個程式執行單元執行的一系列操作,要麼完全執行,要麼完全不執行。事務就是判斷以結果為導向的標準。 一.spring的特性(ACID) (1).原子性(atomicity) 原子性就是一個不可分割的工作單元。簡單的說,就是指事務包含的所有操作要麼全部成功,要麼全部失敗回 ...
事務一般是指資料庫事務,是指作為一個程式執行單元執行的一系列操作,要麼完全執行,要麼完全不執行。事務就是判斷以結果為導向的標準。
一.spring的特性(ACID)
(1).原子性(atomicity)
原子性就是一個不可分割的工作單元。簡單的說,就是指事務包含的所有操作要麼全部成功,要麼全部失敗回滾。因此事務的操作如果成功就必須要完全應用到資料庫,如果失敗則不能對資料庫有任何影響。
(2).一致性(consistency)
一致性就是事務必須是使一個一致性狀態變成另一個狀態,也就是說一個書屋執行之前和執行之後都必須處於一致性狀態。那轉賬來說,假設用戶A和用戶B兩者的錢加起來一共是5000.那麼不管A和B之間如何轉賬,轉多少次,事務結束後兩者的錢加起來還是5000。
(3).隔離性(isolation)
隔離性就是一個事務的執行不能被另一個事務干擾。當多個用戶併發訪問資料庫操作同一張表時,資料庫為每一個用戶開啟的事務,不能被其他事務的操作所干擾,併發事務之間要相互隔離。
(4).持久性(durability)
持久性是指一個事務一旦被提交了,那麼對資料庫數據的改變就是永久的。即使是在數據系統遇到故障的情況下也不會丟失提交事務的操作。
二.spring的隔離級別
* 臟讀:一個事務讀到了另一個事務未提交的數據
* 不可重覆讀:一個事務讀到另一個事務已經提交(update)的數據導致多次查詢結果不一致
* 虛幻讀:一個事務讀到了另一個事務已經提交(insert)的數據導致多次查詢結果不一致。
對於sqlserver和oracle的預設隔離級別是RC,mysql的預設隔離級別是RR。
三.spring的傳播特性(事務有7中傳播機制 )
對於spring的代碼我有寫過一個測試的小demo,在demo裡面有記錄如何添加的事務,同時也列印了日誌記錄最後結果,可以任意擴展。
由於博客園上傳代碼比較麻煩,我就上傳到CSDN上的,想測試的可以去下載。
網址:https://download.csdn.net/download/zj520_/12064006;
四.spring的註意事項
1. 出現Exception是無法回滾的,只有拋出RuntimeException和Error異常時才能回滾。 2. 在事務代碼中捕獲了異常,是無法進行回滾的。
3. 如果是使用的spring+mvc模式。並且spring和mvc都掃描了service層(事務處理層),事務不生效。因為spring會有限載入mvc的配置文件,而事務的配置基本上都是在spring中,因為spring的子容器先於父容器啟動,造成在controller中註入service時還沒有載入事務。
4. mysql的myISAM引擎,是不支持事務的,需要設置為innoDB模式。
5. 事務的開啟必須放到listener裡面載入,如果放到dispatchServlet的配置裡面,事務不生效。
6. 如果在介面中使用@Transactional,只有JDK動態代理才能生效,CGLIB動態代理是不生效的,因為註解是不能繼承的。
五.如果讓Exception可以進行回滾呢?
方法1:@Transactional註解指定rollbackFor=Exception.class
方法2:讓throw的自定義Exception繼承RuntimeException
方法3:使用自定義註解,處理回滾Exception的問題:
@Transactional(rollbackFor=Exception.class)
public @interface DolTransactional {
}