mybatis一級(jí)緩存對(duì)spring事務(wù)隔離級(jí)別表現(xiàn)的影響

先來(lái)看一個(gè)例子囱怕,我們先發(fā)起請(qǐng)求/testA紧武,隨后立即發(fā)起請(qǐng)求/testB:

    @Transactional
    @PostMapping("/testA")
    public void testA() throws InterruptedException {
        // 請(qǐng)求a  第一次查詢  原值為100
        SellerCreditDO testDO = testMapper.findById(TEST_ID);
        System.out.println("request a ==> before change : " + testDO.getCreditScore());

        // sleep期間發(fā)起請(qǐng)求b
        Thread.sleep(5000L);

        // 請(qǐng)求a  第二次查詢
        testDO = testMapper.findById(TEST_ID);
        System.out.println("request a ==> after change : " + testDO.getCreditScore());
    }

    @PostMapping("/testB")
    public void testB() {
        // 請(qǐng)求a第一次查詢執(zhí)行后發(fā)起請(qǐng)求b更新對(duì)應(yīng)值值為90
        SellerCreditDO testDO = testMapper.findById(TEST_ID);
        testDO.setCreditScore(90);
        testMapper.update(testDO);
        System.out.println("request b => change value to 90 -----");
    }

由于spring默認(rèn)使用數(shù)據(jù)庫(kù)的隔離級(jí)別吠裆,而阿里云rds默認(rèn)使用的隔離級(jí)別為read committed按厘,因此這里使用的是rc隔離級(jí)別抵恋,根據(jù)我們對(duì)隔離級(jí)別的認(rèn)識(shí)纲菌,這里的輸出應(yīng)該為:

request a ==> before change : 100
request b => change value to 90 -----
request a ==> after change : 90

但是實(shí)際上挠日,這里的輸出為:

request a ==> before change : 100
request b => change value to 90 -----
request a ==> after change : 100

這里是否是因?yàn)閟pring使用的隔離級(jí)別不是read committed?我們來(lái)嘗試做幾個(gè)修改:


  • 我們將mybatis一級(jí)緩存的scope設(shè)置為statement(mybatis一級(jí)緩存默認(rèn)開啟翰舌,為session級(jí)別嚣潜。):
configuration.setLocalCacheScope(LocalCacheScope.STATEMENT);

再次測(cè)試,我們發(fā)現(xiàn)得到了預(yù)期的輸出:

request a ==> before change : 100
request b => change value to 90 -----
request a ==> after change : 90

  • 不修改mybatis一級(jí)緩存的scope椅贱,去掉testA方法上的@Transaction注解

再次測(cè)試懂算,發(fā)現(xiàn)也能得到預(yù)期的輸出。


有了上面的案例庇麦,經(jīng)過分析框架代碼可以總結(jié)如下:

  1. mybatis一級(jí)緩存默認(rèn)開啟计技,是sqlSession級(jí)別的緩存,在同一個(gè)sqlSession下山橄,對(duì)相同條件的sql查詢結(jié)果會(huì)進(jìn)行緩存垮媒。
  2. sqlSession調(diào)用flush或者close之后,會(huì)清理mybatis一級(jí)緩存航棱;
    session內(nèi)發(fā)生 insert睡雇、update 和 delete 操作時(shí),會(huì)清空緩存饮醇;
    一個(gè)session內(nèi)發(fā)生的insert它抱、update 和 delete 操作,不會(huì)影響其他session內(nèi)的一級(jí)緩存朴艰。
  3. 在spring集成mybatis時(shí)观蓄,如果不開啟事務(wù),spring對(duì)于每次查詢會(huì)使用不同的sqlSession呵晚,因此mybatis一級(jí)緩存是不生效的(每次查詢都是一個(gè)單獨(dú)的事務(wù));
    如果開啟事務(wù)沫屡,spring在事務(wù)內(nèi)會(huì)使用同一個(gè)sqlSession進(jìn)行查詢饵隙,這個(gè)時(shí)候mybatis一級(jí)緩存是生效的,而這個(gè)時(shí)候沮脖,在某些場(chǎng)景下我們只根據(jù)隔離級(jí)別作出的判斷可能就不對(duì)了金矛,需要注意芯急。

建議:一般不要使用mybatis提供的緩存,將一級(jí)緩存設(shè)置為statement級(jí)別驶俊。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末娶耍,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子饼酿,更是在濱河造成了極大的恐慌榕酒,老刑警劉巖,帶你破解...
    沈念sama閱讀 206,126評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件故俐,死亡現(xiàn)場(chǎng)離奇詭異想鹰,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)药版,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,254評(píng)論 2 382
  • 文/潘曉璐 我一進(jìn)店門辑舷,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人槽片,你說(shuō)我怎么就攤上這事何缓。” “怎么了还栓?”我有些...
    開封第一講書人閱讀 152,445評(píng)論 0 341
  • 文/不壞的土叔 我叫張陵碌廓,是天一觀的道長(zhǎng)。 經(jīng)常有香客問我蝙云,道長(zhǎng)氓皱,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 55,185評(píng)論 1 278
  • 正文 為了忘掉前任勃刨,我火速辦了婚禮波材,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘身隐。我一直安慰自己廷区,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,178評(píng)論 5 371
  • 文/花漫 我一把揭開白布贾铝。 她就那樣靜靜地躺著隙轻,像睡著了一般。 火紅的嫁衣襯著肌膚如雪垢揩。 梳的紋絲不亂的頭發(fā)上玖绿,一...
    開封第一講書人閱讀 48,970評(píng)論 1 284
  • 那天,我揣著相機(jī)與錄音叁巨,去河邊找鬼斑匪。 笑死,一個(gè)胖子當(dāng)著我的面吹牛锋勺,可吹牛的內(nèi)容都是我干的蚀瘸。 我是一名探鬼主播狡蝶,決...
    沈念sama閱讀 38,276評(píng)論 3 399
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼贮勃!你這毒婦竟也來(lái)了贪惹?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 36,927評(píng)論 0 259
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤寂嘉,失蹤者是張志新(化名)和其女友劉穎奏瞬,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體垫释,經(jīng)...
    沈念sama閱讀 43,400評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡丝格,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 35,883評(píng)論 2 323
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了棵譬。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片显蝌。...
    茶點(diǎn)故事閱讀 37,997評(píng)論 1 333
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖订咸,靈堂內(nèi)的尸體忽然破棺而出曼尊,到底是詐尸還是另有隱情,我是刑警寧澤脏嚷,帶...
    沈念sama閱讀 33,646評(píng)論 4 322
  • 正文 年R本政府宣布骆撇,位于F島的核電站,受9級(jí)特大地震影響父叙,放射性物質(zhì)發(fā)生泄漏神郊。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,213評(píng)論 3 307
  • 文/蒙蒙 一趾唱、第九天 我趴在偏房一處隱蔽的房頂上張望涌乳。 院中可真熱鬧,春花似錦甜癞、人聲如沸夕晓。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,204評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)蒸辆。三九已至,卻和暖如春析既,著一層夾襖步出監(jiān)牢的瞬間躬贡,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,423評(píng)論 1 260
  • 我被黑心中介騙來(lái)泰國(guó)打工眼坏, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留拂玻,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 45,423評(píng)論 2 352
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像纺讲,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子囤屹,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,722評(píng)論 2 345

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