事務通常是指數據庫事務,是指做爲一個程序執行單元執行的一系列操做,要麼徹底執行,要麼徹底不執行。事務就是判斷以結果爲導向的標準。mysql
(1).原子性(atomicity)
原子性就是一個不可分割的工做單元。簡單的說,就是指事務包含的全部操做要麼所有成功,要麼所有失敗回滾。所以事務的操做若是成功就必需要徹底應用到數據庫,若是失敗則不能對數據庫有任何影響。
(2).一致性(consistency)
一致性就是事務必須是使一個一致性狀態變成另外一個狀態,也就是說一個書屋執行以前和執行以後都必須處於一致性狀態。那轉帳來講,假設用戶A和用戶B二者的錢加起來一共是5000.那麼無論A和B之間如何轉帳,轉多少次,事務結束後二者的錢加起來仍是5000。
(3).隔離性(isolation)
隔離性就是一個事務的執行不能被另外一個事務干擾。當多個用戶併發訪問數據庫操做同一張表時,數據庫爲每個用戶開啓的事務,不能被其餘事務的操做所幹擾,併發事務之間要相互隔離。
(4).持久性(durability)
持久性是指一個事務一旦被提交了,那麼對數據庫數據的改變就是永久的。即便是在數據系統遇到故障的狀況下也不會丟失提交事務的操做。spring
* 髒讀:一個事務讀到了另外一個事務未提交的數據
* 不可重複讀:一個事務讀到另外一個事務已經提交(update)的數據致使屢次查詢結果不一致
* 虛幻讀:一個事務讀到了另外一個事務已經提交(insert)的數據致使屢次查詢結果不一致。
對於sqlserver和oracle的默認隔離級別是RC,mysql的默認隔離級別是RR。sql
對於spring的代碼我有寫過一個測試的小demo,在demo裏面有記錄如何添加的事務,同時也打印了日誌記錄最後結果,能夠任意擴展。數據庫
因爲博客園上傳代碼比較麻煩,我就上傳到CSDN上的,想測試的能夠去下載。併發
網址:https://download.csdn.net/download/zj520_/12064006;mvc
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動態代理是不生效的,由於註解是不能繼承的。oracle
方法1:@Transactional註解指定rollbackFor=Exception.classsqlserver
方法2:讓throw的自定義Exception繼承RuntimeException測試
方法3:使用自定義註解,處理回滾Exception的問題:atom
@Transactional(rollbackFor=Exception.class)
public @interface DolTransactional {
}