@Transactional遇到try catch失效的問題

@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與try..catch同時使用的經驗

@transactional 是我們在java 開發中經常用到的註解,幫助我們非常方便快捷的完成事務管理,尤其在批量處理數據的時候,更是重要,最近業務中遇到瞭這種情況,

批量向數據庫導入數據,這就會出現excel表中有的數據類型符合導入要求,有的不符合,當我們導入的時候要麼就全部成功的導入,要麼就失敗都不導入,如果不用事務的話就會出現數據正確的會導入到數據庫,不正確的就沒導入,造成數據的不一致性,

可我的業務不僅僅是用@transactional 註解完成事務,而且當出現數據不符拋異常的時候還要返回錯誤的提示,所以我還得結核try…catch 塊,問題來瞭,用try…catch就是捕獲異常,然後處理掉,而 @transactional 是要在系統拋異常的時候才能起到事務回滾的作用,

後來我查瞭一些資料,如下操作:

重點就是TransactionAspectSupport.currentTransactionStatus().setRollbackOnly 這個方法,它會起到異常回滾的作用,這樣我就可以在它執行完之後,設置需要返回的自定義的信息

最近又遇到瞭@transactional 註解不起作用的問題瞭,這一次的情況是原來我的mysql 數據庫默認用的是MyISAM 引擎,而這個存儲引擎不支持事務,所以需要對數據庫的進行一下操作:在控制臺輸入  alter table xxx(表名) engine=InnoDB 然後你可以在輸入show create table xxx(表名) 來查看是否修改成功

以上為個人經驗,希望能給大傢一個參考,也希望大傢多多支持WalkonNet。

推薦閱讀: