您好,登錄后才能下訂單哦!
這篇文章給大家分享的是有關如何解決@Transactional遇到try catch失效的問題的內容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。
Springboot中@Transactional遇到了try catch失效了,需要手動回滾
try { user.setExpire(Integer.parseInt(expire)); userService.updateById(user); Host host = hostService.getById(user.getHostId());//查詢數據庫的host信息 updateResponse = proxmoxConfig.updateEffectiveTime(user.getUserName(), expire, host.getHostUrlRequest()); } catch (Exception e) { e.printStackTrace(); TransactionAspectSupport.currentTransactionStatus().setRollbackOnly(); }
@transactional 是我們在java 開發中經常用到的注解,幫助我們非常方便快捷的完成事務管理,尤其在批量處理數據的時候,更是重要,最近業務中遇到了這種情況,
批量向數據庫導入數據,這就會出現excel表中有的數據類型符合導入要求,有的不符合,當我們導入的時候要么就全部成功的導入,要么就失敗都不導入,如果不用事務的話就會出現數據正確的會導入到數據庫,不正確的就沒導入,造成數據的不一致性,
可我的業務不僅僅是用@transactional 注解完成事務,而且當出現數據不符拋異常的時候還要返回錯誤的提示,所以我還得結核try...catch 塊,問題來了,用try...catch就是捕獲異常,然后處理掉,而 @transactional 是要在系統拋異常的時候才能起到事務回滾的作用,
后來我查了一些資料,如下操作:
重點就是TransactionAspectSupport.currentTransactionStatus().setRollbackOnly 這個方法,它會起到異常回滾的作用,這樣我就可以在它執行完之后,設置需要返回的自定義的信息
最近又遇到了@transactional 注解不起作用的問題了,這一次的情況是原來我的mysql 數據庫默認用的是MyISAM 引擎,而這個存儲引擎不支持事務,所以需要對數據庫的進行一下操作:在控制臺輸入 alter table xxx(表名) engine=InnoDB 然后你可以在輸入show create table xxx(表名) 來查看是否修改成功
感謝各位的閱讀!關于“如何解決@Transactional遇到try catch失效的問題”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。