@Transactional注解事务不回滚不起作用无效
@Transactional注解事務(wù)不回滾不起作用無效
以下內(nèi)容均來自http://blog.csdn.net/u011410529/article/details/54287307 轉(zhuǎn)載這幾天在項(xiàng)目里面發(fā)現(xiàn)我使用@Transactional注解事務(wù)之后,拋了異常居然不回滾。后來終于找到了原因。
如果你也出現(xiàn)了這種情況,可以從下面開始排查。
一、特性
先來了解一下@Transactional注解事務(wù)的特性吧,可以更好排查問題
1、service類標(biāo)簽(一般不建議在接口上)上添加@Transactional,可以將整個(gè)類納入spring事務(wù)管理,在每個(gè)業(yè)務(wù)方法執(zhí)行時(shí)都會(huì)開啟一個(gè)事務(wù),不過這些事務(wù)采用相同的管理方式。
2、@Transactional 注解只能應(yīng)用到 public 可見度的方法上。 如果應(yīng)用在protected、private或者 package可見度的方法上,也不會(huì)報(bào)錯(cuò),不過事務(wù)設(shè)置不會(huì)起作用。
3、默認(rèn)情況下,Spring會(huì)對unchecked異常進(jìn)行事務(wù)回滾;如果是checked異常則不回滾。
辣么什么是checked異常,什么是unchecked異常
Java里面將派生于Error或者RuntimeException(比如空指針,1/0)的異常稱為unchecked異常,其他繼承自java.lang.Exception得異常統(tǒng)稱為Checked Exception,如IOException、TimeoutException等
辣么再通俗一點(diǎn):你寫代碼出現(xiàn)的空指針等異常,會(huì)被回滾,文件讀寫,網(wǎng)絡(luò)出問題,spring就沒法回滾了
4、只讀事務(wù):
@Transactional(propagation=Propagation.NOT_SUPPORTED,readOnly=true)
只讀標(biāo)志只在事務(wù)啟動(dòng)時(shí)應(yīng)用,否則即使配置也會(huì)被忽略。
啟動(dòng)事務(wù)會(huì)增加線程開銷,數(shù)據(jù)庫因共享讀取而鎖定(具體跟數(shù)據(jù)庫類型和事務(wù)隔離級(jí)別有關(guān))。通常情況下,僅是讀取數(shù)據(jù)時(shí),不必設(shè)置只讀事務(wù)而增加額外的系統(tǒng)開銷。
二:事務(wù)傳播模式
Propagation枚舉了多種事務(wù)傳播模式,部分列舉如下:
-
1、REQUIRED(默認(rèn)模式):業(yè)務(wù)方法需要在一個(gè)容器里運(yùn)行。如果方法運(yùn)行時(shí),已經(jīng)處在一個(gè)事務(wù)中,那么加入到這個(gè)事務(wù),否則自己新建一個(gè)新的事務(wù)。
-
2、NOT_SUPPORTED:聲明方法不需要事務(wù)。如果方法沒有關(guān)聯(lián)到一個(gè)事務(wù),容器不會(huì)為他開啟事務(wù),如果方法在一個(gè)事務(wù)中被調(diào)用,該事務(wù)會(huì)被掛起,調(diào)用結(jié)束后,原先的事務(wù)會(huì)恢復(fù)執(zhí)行。
-
3、REQUIRESNEW:不管是否存在事務(wù),該方法總匯為自己發(fā)起一個(gè)新的事務(wù)。如果方法已經(jīng)運(yùn)行在一個(gè)事務(wù)中,則原有事務(wù)掛起,新的事務(wù)被創(chuàng)建。
-
4、 MANDATORY:該方法只能在一個(gè)已經(jīng)存在的事務(wù)中執(zhí)行,業(yè)務(wù)方法不能發(fā)起自己的事務(wù)。如果在沒有事務(wù)的環(huán)境下被調(diào)用,容器拋出例外。
-
5、SUPPORTS:該方法在某個(gè)事務(wù)范圍內(nèi)被調(diào)用,則方法成為該事務(wù)的一部分。如果方法在該事務(wù)范圍外被調(diào)用,該方法就在沒有事務(wù)的環(huán)境下執(zhí)行。
-
6、NEVER:該方法絕對不能在事務(wù)范圍內(nèi)執(zhí)行。如果在就拋例外。只有該方法沒有關(guān)聯(lián)到任何事務(wù),才正常執(zhí)行。
-
7、NESTED:如果一個(gè)活動(dòng)的事務(wù)存在,則運(yùn)行在一個(gè)嵌套的事務(wù)中。如果沒有活動(dòng)事務(wù),則按REQUIRED屬性執(zhí)行。它使用了一個(gè)單獨(dú)的事務(wù),這個(gè)事務(wù)擁有多個(gè)可以回滾的保存點(diǎn)。內(nèi)部事務(wù)的回滾不會(huì)對外部事務(wù)造成影響。它只對DataSourceTransactionManager事務(wù)管理器起效。
上面引用至事務(wù)傳播模式
二:解決Transactional注解不回滾
1、檢查你方法是不是public的
2、你的異常類型是不是unchecked異常
如果我想check異常也想回滾怎么辦,注解上面寫明異常類型即可
- 1
- 1
類似的還有norollbackFor,自定義不回滾的異常
3、數(shù)據(jù)庫引擎要支持事務(wù),如果是MySQL,注意表要使用支持事務(wù)的引擎,比如innodb,如果是myisam,事務(wù)是不起作用的
4、是否開啟了對注解的解析
<tx:annotation-driven transaction-manager="transactionManager" proxy-target-class="true"/>- 1
- 2
- 1
- 2
5、spring是否掃描到你這個(gè)包,如下是掃描到org.test下面的包
<context:component-scan base-package="org.test" ></context:component-scan>- 1
- 1
以上,以后有再添加
轉(zhuǎn)載于:https://www.cnblogs.com/qinshuipo/articles/7463238.html
總結(jié)
以上是生活随笔為你收集整理的@Transactional注解事务不回滚不起作用无效的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 跳转到页面后加载一个请求的方法
- 下一篇: 关于mybatis的@Param注解和参