@Transactional注解失效場(chǎng)景

通過@Transactional進(jìn)行事務(wù)控制是我們?cè)谌粘i_發(fā)中非常常見的使用方式情妖,雖然用起來感覺很簡(jiǎn)單,但是其內(nèi)部的實(shí)現(xiàn)細(xì)節(jié)較多霹俺,稍微不注意就會(huì)出現(xiàn)莫名其妙的事務(wù)失效他挎。這里記錄一下其失效的六種場(chǎng)景。

最好不要加到接口上

雖然@Transactional可以添加到接口上界弧,但是如果此時(shí)將動(dòng)態(tài)代理由JDK改為CGLib的話凡蜻,會(huì)出現(xiàn)失效。因?yàn)镃GLib是直接對(duì)類進(jìn)行代理夹纫,導(dǎo)致接口不生效咽瓷。

1)數(shù)據(jù)庫(kù)引擎不支持,事務(wù)失效

MySQL數(shù)據(jù)庫(kù)默認(rèn)引擎為INNODB舰讹,此引擎支持事務(wù)茅姜。但是當(dāng)將引擎切換為MYISAM時(shí),由于該引擎不支持事務(wù),所以會(huì)出現(xiàn)失誤失效钻洒。

2)不能加載非public方法上

Spring AOP代理時(shí)奋姿,在其內(nèi)部最終會(huì)檢查目標(biāo)方法的修飾符是否為public,如果不是public則不會(huì)獲取@Transactional的屬性信息素标,導(dǎo)致事務(wù)失效称诗。但是在protected和private方法上雖然事務(wù)失效了,但不會(huì)出現(xiàn)任何報(bào)錯(cuò)头遭,此處需注意

protected TransactionAttribute computeTransactionAttribute(Method method,
    Class<?> targetClass) {
        // Don't allow no-public methods as required.
        if (allowPublicMethodsOnly() && !Modifier.isPublic(method.getModifiers())) {
        return null;
} 

3)@Transactional中propagation屬性配置錯(cuò)誤

事務(wù)的傳播機(jī)制總共有七種寓免,分別為:

image.png

那么當(dāng)配置以下三種事務(wù)傳播機(jī)制時(shí),會(huì)導(dǎo)致事務(wù)失效
SUPPORTS:如果當(dāng)前有事務(wù)计维,則沿用當(dāng)前事務(wù)袜香,如果沒有,以非事務(wù)方式運(yùn)行
NOT_SUPPORTED:以非事務(wù)方式運(yùn)行鲫惶,如果當(dāng)前存在事務(wù)蜈首,則把當(dāng)前事務(wù)掛起
NEVER:以非事務(wù)方式運(yùn)行,如果當(dāng)前存在事務(wù)欠母,則拋出異常

4)使用自定義異常

Spring默認(rèn)拋出繼承自 RuntimeException 的異郴恫撸或者Error時(shí),才會(huì)出現(xiàn)事務(wù)回滾赏淌,其他類型的異常不會(huì)觸發(fā)事務(wù)回滾踩寇。如果需要拋出指定類型的異常,如自定義異常六水。同時(shí)需要事務(wù)回滾姑荷。需要通過rollbackFor 進(jìn)行指定。同時(shí)對(duì)于自定義異常的子類同樣也會(huì)觸發(fā)事務(wù)回滾缩擂。

@Transactional(rollbackFor= MyException.class)

5)同類中方法調(diào)用,事務(wù)失效

A方法沒有添加事務(wù)注解添寺,B方法添加事務(wù)注解胯盯。并且A調(diào)用B。此時(shí)當(dāng)外部調(diào)用A方法時(shí)计露,B方式事務(wù)不會(huì)生效博脑。因?yàn)樵赟pring AOP中,事務(wù)方法只有被當(dāng)前類以外的代碼調(diào)用票罐,Spring才會(huì)生成代理對(duì)象叉趣。

6)catch捕獲異常,事務(wù)失效

假設(shè)B中insertInfo執(zhí)行時(shí)會(huì)出現(xiàn)異常该押,但是A對(duì)下游的B出現(xiàn)的異常進(jìn)行的手動(dòng)捕獲并進(jìn)行處理疗杉,所以A會(huì)認(rèn)為當(dāng)前事務(wù)正常提交。此時(shí)就會(huì)出現(xiàn)B事務(wù)回滾蚕礼,但A執(zhí)行成功烟具。導(dǎo)致數(shù)據(jù)出現(xiàn)不一致梢什。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市朝聋,隨后出現(xiàn)的幾起案子嗡午,更是在濱河造成了極大的恐慌,老刑警劉巖冀痕,帶你破解...
    沈念sama閱讀 211,194評(píng)論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件荔睹,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡言蛇,警方通過查閱死者的電腦和手機(jī)僻他,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,058評(píng)論 2 385
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來猜极,“玉大人中姜,你說我怎么就攤上這事「” “怎么了丢胚?”我有些...
    開封第一講書人閱讀 156,780評(píng)論 0 346
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)受扳。 經(jīng)常有香客問我携龟,道長(zhǎng),這世上最難降的妖魔是什么勘高? 我笑而不...
    開封第一講書人閱讀 56,388評(píng)論 1 283
  • 正文 為了忘掉前任峡蟋,我火速辦了婚禮,結(jié)果婚禮上华望,老公的妹妹穿的比我還像新娘蕊蝗。我一直安慰自己,他們只是感情好赖舟,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,430評(píng)論 5 384
  • 文/花漫 我一把揭開白布蓬戚。 她就那樣靜靜地躺著,像睡著了一般宾抓。 火紅的嫁衣襯著肌膚如雪子漩。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,764評(píng)論 1 290
  • 那天石洗,我揣著相機(jī)與錄音幢泼,去河邊找鬼。 笑死讲衫,一個(gè)胖子當(dāng)著我的面吹牛缕棵,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 38,907評(píng)論 3 406
  • 文/蒼蘭香墨 我猛地睜開眼挥吵,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼重父!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起忽匈,我...
    開封第一講書人閱讀 37,679評(píng)論 0 266
  • 序言:老撾萬榮一對(duì)情侶失蹤房午,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后丹允,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體郭厌,經(jīng)...
    沈念sama閱讀 44,122評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,459評(píng)論 2 325
  • 正文 我和宋清朗相戀三年雕蔽,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了折柠。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,605評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡批狐,死狀恐怖扇售,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情嚣艇,我是刑警寧澤承冰,帶...
    沈念sama閱讀 34,270評(píng)論 4 329
  • 正文 年R本政府宣布,位于F島的核電站食零,受9級(jí)特大地震影響困乒,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜贰谣,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,867評(píng)論 3 312
  • 文/蒙蒙 一娜搂、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧吱抚,春花似錦百宇、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,734評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至憋肖,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間婚苹,已是汗流浹背岸更。 一陣腳步聲響...
    開封第一講書人閱讀 31,961評(píng)論 1 265
  • 我被黑心中介騙來泰國(guó)打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留膊升,地道東北人怎炊。 一個(gè)月前我還...
    沈念sama閱讀 46,297評(píng)論 2 360
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親评肆。 傳聞我的和親對(duì)象是個(gè)殘疾皇子债查,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,472評(píng)論 2 348

推薦閱讀更多精彩內(nèi)容