亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

解決@Transactional注解事務不回滾不起作用的問題

 更新時間:2021年02月23日 11:04:20   作者:一年e度的夏天  
這篇文章主要介紹了解決@Transactional注解事務不回滾不起作用的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧

這幾天在項目里面發(fā)現(xiàn)我使用@Transactional注解事務之后,拋了異常居然不回滾。后來終于找到了原因。

如果你也出現(xiàn)了這種情況,可以從下面開始排查。

一、特性

先來了解一下@Transactional注解事務的特性吧,可以更好排查問題

1、service類標簽(一般不建議在接口上)上添加@Transactional,可以將整個類納入spring事務管理,在每個業(yè)務方法執(zhí)行時都會開啟一個事務,不過這些事務采用相同的管理方式。

2、@Transactional 注解只能應用到 public 可見度的方法上。 如果應用在protected、private或者 package可見度的方法上,也不會報錯,不過事務設置不會起作用。

3、默認情況下,Spring會對unchecked異常進行事務回滾;如果是checked異常則不回滾。

辣么什么是checked異常,什么是unchecked異常

java里面將派生于Error或者RuntimeException(比如空指針,1/0)的異常稱為unchecked異常,其他繼承自java.lang.Exception得異常統(tǒng)稱為Checked Exception,如IOException、TimeoutException等

辣么再通俗一點:

你寫代碼出現(xiàn)的空指針等異常,會被回滾,文件讀寫,網(wǎng)絡出問題,spring就沒法回滾了。然后我教大家怎么記這個,因為很多同學容易弄混,你寫代碼的時候有些IOException我們的編譯器是能夠檢測到的,說以叫checked異常,你寫代碼的時候空指針等死檢測不到的,所以叫unchecked異常。這樣是不是好記一些啦

4、只讀事務:

@Transactional(propagation=Propagation.NOT_SUPPORTED,readOnly=true)

只讀標志只在事務啟動時應用,否則即使配置也會被忽略。

啟動事務會增加線程開銷,數(shù)據(jù)庫因共享讀取而鎖定(具體跟數(shù)據(jù)庫類型和事務隔離級別有關(guān))。通常情況下,僅是讀取數(shù)據(jù)時,不必設置只讀事務而增加額外的系統(tǒng)開銷。

二:事務傳播模式

Propagation枚舉了多種事務傳播模式,部分列舉如下:

1、REQUIRED(默認模式):業(yè)務方法需要在一個容器里運行。如果方法運行時,已經(jīng)處在一個事務中,那么加入到這個事務,否則自己新建一個新的事務。

2、NOT_SUPPORTED:聲明方法不需要事務。如果方法沒有關(guān)聯(lián)到一個事務,容器不會為他開啟事務,如果方法在一個事務中被調(diào)用,該事務會被掛起,調(diào)用結(jié)束后,原先的事務會恢復執(zhí)行。

3、REQUIRESNEW:不管是否存在事務,該方法總匯為自己發(fā)起一個新的事務。如果方法已經(jīng)運行在一個事務中,則原有事務掛起,新的事務被創(chuàng)建。

4、 MANDATORY:該方法只能在一個已經(jīng)存在的事務中執(zhí)行,業(yè)務方法不能發(fā)起自己的事務。如果在沒有事務的環(huán)境下被調(diào)用,容器拋出例外。

5、SUPPORTS:該方法在某個事務范圍內(nèi)被調(diào)用,則方法成為該事務的一部分。如果方法在該事務范圍外被調(diào)用,該方法就在沒有事務的環(huán)境下執(zhí)行。

6、NEVER:該方法絕對不能在事務范圍內(nèi)執(zhí)行。如果在就拋例外。只有該方法沒有關(guān)聯(lián)到任何事務,才正常執(zhí)行。

7、NESTED:如果一個活動的事務存在,則運行在一個嵌套的事務中。如果沒有活動事務,則按REQUIRED屬性執(zhí)行。它使用了一個單獨的事務,這個事務擁有多個可以回滾的保存點。內(nèi)部事務的回滾不會對外部事務造成影響。它只對DataSourceTransactionManager事務管理器起效。

三:解決Transactional注解不回滾

1、檢查你方法是不是public的

2、你的異常類型是不是unchecked異常

如果我想check異常也想回滾怎么辦,注解上面寫明異常類型即可

@Transactional(rollbackFor=Exception.class) 

類似的還有norollbackFor,自定義不回滾的異常

3、數(shù)據(jù)庫引擎要支持事務,如果是MySQL,注意表要使用支持事務的引擎,比如innodb,如果是myisam,事務是不起作用的

4、是否開啟了對注解的解析

<tx:annotation-driven transaction-manager="transactionManager" proxy-target-class="true"/>

5、spring是否掃描到你這個包,如下是掃描到org.test下面的包

<context:component-scan base-package="org.test" ></context:component-scan>

6、檢查是不是同一個類中的方法調(diào)用(如a方法調(diào)用同一個類中的b方法)

7、異常是不是被你catch住了

以上,以后有再添加吧~

補充:@Transactional事務幾點注意

這里面有幾點需要大家留意:

A. 一個功能是否要事務,必須納入設計、編碼考慮。不能僅僅完成了基本功能就ok。

B. 如果加了事務,必須做好開發(fā)環(huán)境測試(測試環(huán)境也盡量觸發(fā)異常、測試回滾),確保事務生效。

C. 以下列了事務使用過程的注意事項,請大家留意。

1. 不要在接口上聲明@Transactional ,而要在具體類的方法上使用 @Transactional 注解,否則注解可能無效。

2.不要圖省事,將@Transactional放置在類級的聲明中,放在類聲明,會使得所有方法都有事務。故@Transactional應該放在方法級別,不需要使用事務的方法,就不要放置事務,比如查詢方法。否則對性能是有影響的。

3.使用了@Transactional的方法,對同一個類里面的方法調(diào)用, @Transactional無效。比如有一個類Test,它的一個方法A,A再調(diào)用Test本類的方法B(不管B是否public還是private),但A沒有聲明注解事務,而B有。則外部調(diào)用A之后,B的事務是不會起作用的。(經(jīng)常在這里出錯)

4.使用了@Transactional的方法,只能是public,@Transactional注解的方法都是被外部其他類調(diào)用才有效,故只能是public。道理和上面的有關(guān)聯(lián)。故在 protected、private 或者 package-visible 的方法上使用 @Transactional 注解,它也不會報錯,但事務無效。

5.經(jīng)過在ICORE-CLAIM中測試,效果如下:

A.拋出受查異常XXXException,事務會回滾。

B.拋出運行時異常NullPointerException,事務會回滾。

C.Quartz中,execute直接調(diào)用加了@Transactional方法,可以回滾;間接調(diào)用,不會回滾。(即上文3點提到的)

D.異步任務中,execute直接調(diào)用加了@Transactional方法,可以回滾;間接調(diào)用,不會回滾。(即上文3點提到的)

E.在action中加上@Transactional,不會回滾。切記不要在action中加上事務。

F.在service中加上@Transactional,如果是action直接調(diào)該方法,會回滾,如果是間接調(diào),不會回滾。(即上文3提到的)

G.在service中的private加上@Transactional,事務不會回滾。

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。如有錯誤或未考慮完全的地方,望不吝賜教。

相關(guān)文章

  • Spring Data Redis對象緩存序列化問題解決

    Spring Data Redis對象緩存序列化問題解決

    相信在項目中,你一定是經(jīng)常使用Redis,在使用時,有沒有遇到同我一樣,對象緩存序列化問題的呢,本文主要介紹了Spring Data Redis對象緩存序列化問題解決,感興趣的可以了解一下
    2024-01-01
  • Idea如何配置Maven才能優(yōu)先從本地倉庫獲取依賴(親測方法有效)

    Idea如何配置Maven才能優(yōu)先從本地倉庫獲取依賴(親測方法有效)

    對于Idea怎么配置Maven才能優(yōu)先從本地倉庫獲取依賴,網(wǎng)上說法有很多種,都不太靠譜,最終都沒有效果,最好的解決方法是通過修改maven配置文件settings.xml,本文給大家介紹的非常詳細,需要的朋友參考下吧
    2023-10-10
  • springmvc與mybatis集成配置實例詳解

    springmvc與mybatis集成配置實例詳解

    這篇文章主要介紹了springmvc與mybatis集成配置實例詳解的相關(guān)資料,非常不錯,具有參考借鑒價值,需要的朋友可以參考下
    2016-09-09
  • idea中l(wèi)ombok的用法

    idea中l(wèi)ombok的用法

    lombok是開源的代碼生成庫,是一款非常實用的小工具,在更改實體類時只需要修改屬性即可,減少了很多重復代碼的編寫工作,今天小編給大家介紹idea中l(wèi)ombok的用法,感興趣的朋友一起看看吧
    2021-12-12
  • java中的動態(tài)代理與責任鏈模式詳解

    java中的動態(tài)代理與責任鏈模式詳解

    這篇文章主要介紹了java中的動態(tài)代理與責任鏈模式詳解,動態(tài)代理提供了一種靈活且非侵入式的方式,可以對對象的行為進行定制和擴展,它在代碼重用、解耦和業(yè)務邏輯分離、性能優(yōu)化以及系統(tǒng)架構(gòu)中起到了重要的作用,需要的朋友可以參考下
    2023-08-08
  • 詳解SpringCloud mysql實現(xiàn)配置中心

    詳解SpringCloud mysql實現(xiàn)配置中心

    這篇文章主要介紹了詳解SpringCloud mysql實現(xiàn)配置中心,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-09-09
  • idea注解參數(shù)換行時間日期格式設置方法

    idea注解參數(shù)換行時間日期格式設置方法

    這篇文章主要介紹了idea注解參數(shù)換行時間日期格式設置方法,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-05-05
  • SpringBoot錯誤提示400狀態(tài)問題

    SpringBoot錯誤提示400狀態(tài)問題

    這篇文章主要介紹了SpringBoot錯誤提示400狀態(tài)問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-08-08
  • java更改圖片大小示例分享

    java更改圖片大小示例分享

    這篇文章主要介紹了java更改圖片大小示例,方法中指定路徑 ,舊文件名稱 ,新文件名稱,n 改變倍數(shù)就可以完成更改圖片大小,需要的朋友可以參考下
    2014-03-03
  • Maven?Pom?文件中的隱式依賴導致Jar沖突問題

    Maven?Pom?文件中的隱式依賴導致Jar沖突問題

    這篇文章主要介紹了Maven?Pom?文件中的隱式依賴導致Jar沖突問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-12-12

最新評論