今天碰到乙個鬱悶的問題。。。spring配置的事務回滾無效。。
而且奇怪的是**中總共操作了3張表的資料,但是其中2張表在發生異常時回滾了,另一張表死活不回滾。
開始還以為是事務巢狀導致的,但是搜尋一番發現spring預設的事務傳播機制是支援巢狀事務,並且發生異常會全部回滾了···
這就奇了怪了,試了好幾遍仍然是其中一張表不回滾···就感覺應該不是spring的問題,就出在這張表的身上。
要說表有什麼不同,除了資料庫引擎能夠影響之外其他應該對事務沒什麼影響吧。
果不其然,看了下那張不回滾的表,發現他的資料庫引擎是myisam,稍稍搜尋了下,myisam為了效能不支援事務···真是坑,換成innodb就沒問題了,這個小問題困擾了一天,特此記錄一下。
spring事務回滾
註解方式宣告事務,該事務宣告的範圍是service中的方法,而一般的事務宣告時不是宣告在 業務邏輯方法上的,而是宣告在單一的資料庫操作方法上的 transactional publicclassuserserviceimplimplementsuserservice,newint thrownewe...
spring事務回滾
1 核心 只有丟擲 runtimeexception 才會回滾,其他情況都不會 2 基本 1.spring事務配置 advice ref txadvice 2.service層 public class personservice 3.sqlmap values name age version s...
spring事務回滾
被攔截的方法需顯式丟擲異常,並不能經任何處理,這樣aop 才能捕獲到方法的異常,才能進行回滾,預設情況下aop只捕獲runtimeexcetpion的異常,但可以通過 配置來捕獲特定的異常並回滾換句話說在service的方法中不使用try catch 或者在catch中最後加上throw new r...