java - Spring事務回滾問題
問題描述
Spring事物,在service層注入事物,進行兩個insert操作,在service方法中要自己拋出異常然后指定回滾嗎?還是一個insert沒有成功自己也不用拋出異常就會回滾嗎?這里使用mybatis的代理dao實現,insert失敗時會有提示或異常拋出嗎
問題解答
回答1:使用@Transaction(rollbackFor=Throwable.class)注解到Service類上或具體的方法上,需要注意的是@Transaction注解默認只對RuntimeException異常捕獲并回滾,也就是說如果你拋出的是Exception異常將不進行回滾,所以要記得加上rollbackFor=Throwable.class指定所有的異常都進行回滾
回答2:同意@正能量前線的答案,并且補充下,如果在一個方法中進行多次操作,需要考慮事務的傳播范圍,當然默認是 propagation = Propagation.REQUIRED,意思是說: 如果當前沒有事務,就新建一個事務,如果已經存在一個事務中,加入到這個事務中.
回答3:如果有編譯異常拋出就可以 不可以自己捕獲處理 你既然用了spring框架 ,自己捕獲并處理了異常,框架不會幫你回滾了,前提是你在spring配置文件里邊配置了事務的回滾策略同意一樓所說默認運行異常回滾,事務是加在service層的,你那兩個insert方法本身并沒有事務,所以不需要考慮傳播行為。
回答4:看了前面前面兩位的回答,我再補充下。在Spring事務默認是基于接口的JDK代理。所以在你的Service層調用的兩個insert方法,如果insert也是service層方法,那必須是接口方法,如果是私有方法,則私有方法不會回滾。還要注意多線程情況下的事務問題。
相關文章:
1. 在mybatis使用mysql的ON DUPLICATE KEY UPDATE語法實現存在即更新應該使用哪個標簽?2. mysql - 表名稱前綴到底有啥用?3. Navicat for mysql 中以json格式儲存的數據存在大量反斜杠,如何去除?4. mysql - 數據庫表中,兩個表互為外鍵參考如何解決5. 哭遼 求大佬解答 控制器的join方法怎么轉模型方法6. mysql儲存json錯誤7. mysql - 怎么生成這個sql表?8. 怎么php怎么通過數組顯示sql查詢結果呢,查詢結果有多條,如圖。9. sql語句 - 如何在mysql中批量添加用戶?10. 編輯成功不顯示彈窗
