十六、spring事務(wù)之事務(wù)傳播機(jī)制和隔離級別

Spring事務(wù)傳播行為

運(yùn)用Spring事務(wù)康铭,必須要深入理解它的傳播機(jī)制,否則會遇到各種意想不到的坑,Spring定義了七種傳播行為赌髓。

public interface TransactionDefinition {
    int PROPAGATION_REQUIRED = 0;
    int PROPAGATION_SUPPORTS = 1;
    int PROPAGATION_MANDATORY = 2;
    int PROPAGATION_REQUIRES_NEW = 3;
    int PROPAGATION_NOT_SUPPORTED = 4;
    int PROPAGATION_NEVER = 5;
    int PROPAGATION_NESTED = 6;
}

含義如下:

傳播行為 官方含義 簡單理解
PROPAGATION_REQUIRED 表示當(dāng)前方法必須在一個事務(wù)中運(yùn)行从藤。如果一個現(xiàn)有事務(wù)正在進(jìn)行中,該方法將在那個事務(wù)中運(yùn)行锁蠕,否則就要開始一個新事務(wù) 有事務(wù)就用已有的夷野,沒有就重新開啟一個
PROPAGATION_SUPPORTS 表示當(dāng)前方法不需要事務(wù)性上下文,但是如果有一個事務(wù)已經(jīng)在運(yùn)行的話荣倾,它也可以在這個事務(wù)里運(yùn)行 有事務(wù)就用已有的悯搔,沒有也不會重新開啟
PROPAGATION_MANDATORY 表示該方法必須運(yùn)行在一個事務(wù)中。如果當(dāng)前沒有事務(wù)正在發(fā)生舌仍,將拋出一個異常 必須要有事務(wù)妒貌,沒事務(wù)拋異常
PROPAGATION_REQUIRES_NEW 表示當(dāng)前方法必須在它自己的事務(wù)里運(yùn)行通危。一個新的事務(wù)將被啟動,而且如果有一個現(xiàn)有事務(wù)在運(yùn)行的話灌曙,則將在這個方法運(yùn)行期間被掛起 開啟新事務(wù)菊碟,若當(dāng)前已有事務(wù),掛起當(dāng)前事務(wù)
PROPAGATION_NOT_SUPPORTED 表示該方法不應(yīng)該在一個事務(wù)中運(yùn)行在刺。如果一個現(xiàn)有事務(wù)正在進(jìn)行中逆害,它將在該方法的運(yùn)行期間被掛起 不需要事務(wù),若當(dāng)前已有事務(wù)蚣驼,掛起當(dāng)前事務(wù)
PROPAGATION_NEVER 表示當(dāng)前的方法不應(yīng)該在一個事務(wù)中運(yùn)行魄幕。如果一個事務(wù)正在進(jìn)行,則會拋出一個異常 不需要事務(wù)隙姿,若當(dāng)前已有事務(wù)梅垄,拋出異常
PROPAGATION_NESTED 表示如果當(dāng)前正有一個事務(wù)在進(jìn)行中,則該方法應(yīng)當(dāng)運(yùn)行在一個嵌套式事務(wù)中输玷。被嵌套的事務(wù)可以獨(dú)立于封裝事務(wù)進(jìn)行提交或回滾队丝。如果封裝事務(wù)不存在,行為就像PROPAGATION_REQUIRES一樣 嵌套事務(wù)欲鹏,如果外部事務(wù)回滾机久,則嵌套事務(wù)也會回滾!E夂俊膘盖!外部事務(wù)提交的時候,嵌套它才會被提交尤误。嵌套事務(wù)回滾不會影響外部事務(wù)侠畔。

Spring的@Transactional默認(rèn)是PROPAGATION_REQUIRED。

隔離級別

隔離級別轉(zhuǎn)載自http://www.javaseo.cn/article/88/

Spring的事務(wù)隔離級別最終還是交給數(shù)據(jù)庫處理损晤,Spring并沒有做特殊處理软棺。

  1. Read uncommitted 讀未提交
    公司發(fā)工資了,把50000元打到我的賬號上尤勋,但是該事務(wù)并未提交喘落,而我正好去查看賬戶,發(fā)現(xiàn)工資已經(jīng)到賬最冰,是50000元整瘦棋,非常高興∨冢可是不幸的是赌朋,領(lǐng)導(dǎo)發(fā)現(xiàn)發(fā)給的工資金額不對,是2000元,于是迅速回滾了事務(wù)沛慢,修改金額后服球,將事務(wù)提交,最后我實(shí)際的工資只有2000元颠焦,空歡喜一場斩熊。
    臟讀是兩個并發(fā)的事務(wù),“事務(wù)A:領(lǐng)導(dǎo)發(fā)工資”伐庭、“事務(wù)B:我查詢工資賬戶”粉渠,事務(wù)B讀取了事務(wù)A尚未提交的數(shù)據(jù)。
    當(dāng)隔離級別設(shè)置為Read uncommitted時圾另,就可能出現(xiàn)臟讀霸株,如何避免臟讀,請看下一個隔離級別集乔。
  2. Read committed 讀提交
    我拿著工資卡去消費(fèi)去件,系統(tǒng)讀取到卡里確實(shí)有2000元,而此時老婆也正好在網(wǎng)上轉(zhuǎn)賬扰路,把工資卡的2000元轉(zhuǎn)到她賬戶尤溜,并在我之前提交了事務(wù),當(dāng)我扣款時汗唱,系統(tǒng)檢查到工資卡已經(jīng)沒有錢宫莱,扣款失敗,十分納悶哩罪,明明卡里有錢授霸,為何......
    不可重復(fù)讀是兩個并發(fā)的事務(wù),“事務(wù)A:消費(fèi)”际插、“事務(wù)B:老婆網(wǎng)上轉(zhuǎn)賬”碘耳,事務(wù)A事先讀取了數(shù)據(jù),事務(wù)B緊接了更新了數(shù)據(jù)框弛,并提交了事務(wù)辛辨,而事務(wù)A再次讀取該數(shù)據(jù)時,數(shù)據(jù)已經(jīng)發(fā)生了改變功咒。
    當(dāng)隔離級別設(shè)置為Read committed時愉阎,避免了臟讀绞蹦,但是可能會造成不可重復(fù)讀力奋。
  3. Repeatable read 重復(fù)讀
    當(dāng)隔離級別設(shè)置為Repeatable read時,可以避免不可重復(fù)讀幽七。當(dāng)我拿著工資卡去消費(fèi)時景殷,一旦系統(tǒng)開始讀取工資卡信息(即事務(wù)開始),我老婆就不可能對該記錄進(jìn)行修改,也就是不能在此時轉(zhuǎn)賬猿挚。
    雖然Repeatable read避免了不可重復(fù)讀咐旧,但還有可能出現(xiàn)幻讀。例如:老婆工作在銀行部門绩蜻,她時常通過銀行內(nèi)部系統(tǒng)查看我的信用卡消費(fèi)記錄铣墨。有一天,她正查詢到我當(dāng)月信用卡的總消費(fèi)金額(select sum(amount) from transaction where month = 本月)為80元办绝,而我此時正好在外面吃完大餐后在收銀臺買單伊约,消費(fèi)1000元,即新增了一條1000元的消費(fèi)記錄(insert transaction ... )孕蝉,并提交了事務(wù)屡律,隨后老婆將我的當(dāng)月信用卡消費(fèi)的明細(xì)打印到A4紙上,卻發(fā)現(xiàn)消費(fèi)總額為1080元降淮,老婆很詫異超埋,以為出現(xiàn)了幻覺,幻讀就這樣產(chǎn)生了佳鳖。
  4. Serializable (串行化):可避免臟讀霍殴、不可重復(fù)讀、幻讀的發(fā)生系吩。
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末繁成,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子淑玫,更是在濱河造成了極大的恐慌巾腕,老刑警劉巖,帶你破解...
    沈念sama閱讀 212,080評論 6 493
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件絮蒿,死亡現(xiàn)場離奇詭異尊搬,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)土涝,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,422評論 3 385
  • 文/潘曉璐 我一進(jìn)店門佛寿,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人但壮,你說我怎么就攤上這事冀泻。” “怎么了蜡饵?”我有些...
    開封第一講書人閱讀 157,630評論 0 348
  • 文/不壞的土叔 我叫張陵弹渔,是天一觀的道長。 經(jīng)常有香客問我溯祸,道長肢专,這世上最難降的妖魔是什么舞肆? 我笑而不...
    開封第一講書人閱讀 56,554評論 1 284
  • 正文 為了忘掉前任,我火速辦了婚禮博杖,結(jié)果婚禮上椿胯,老公的妹妹穿的比我還像新娘。我一直安慰自己剃根,他們只是感情好哩盲,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,662評論 6 386
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著狈醉,像睡著了一般种冬。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上舔糖,一...
    開封第一講書人閱讀 49,856評論 1 290
  • 那天娱两,我揣著相機(jī)與錄音,去河邊找鬼金吗。 笑死十兢,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的摇庙。 我是一名探鬼主播旱物,決...
    沈念sama閱讀 39,014評論 3 408
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼卫袒!你這毒婦竟也來了宵呛?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,752評論 0 268
  • 序言:老撾萬榮一對情侶失蹤夕凝,失蹤者是張志新(化名)和其女友劉穎宝穗,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體码秉,經(jīng)...
    沈念sama閱讀 44,212評論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡逮矛,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,541評論 2 327
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了转砖。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片须鼎。...
    茶點(diǎn)故事閱讀 38,687評論 1 341
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖府蔗,靈堂內(nèi)的尸體忽然破棺而出晋控,到底是詐尸還是另有隱情,我是刑警寧澤姓赤,帶...
    沈念sama閱讀 34,347評論 4 331
  • 正文 年R本政府宣布赡译,位于F島的核電站,受9級特大地震影響模捂,放射性物質(zhì)發(fā)生泄漏捶朵。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,973評論 3 315
  • 文/蒙蒙 一狂男、第九天 我趴在偏房一處隱蔽的房頂上張望综看。 院中可真熱鬧,春花似錦岖食、人聲如沸红碑。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,777評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽析珊。三九已至,卻和暖如春蔑穴,著一層夾襖步出監(jiān)牢的瞬間忠寻,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,006評論 1 266
  • 我被黑心中介騙來泰國打工存和, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留奕剃,地道東北人。 一個月前我還...
    沈念sama閱讀 46,406評論 2 360
  • 正文 我出身青樓捐腿,卻偏偏與公主長得像纵朋,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子茄袖,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,576評論 2 349

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