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