溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

Mybatis中如何實(shí)現(xiàn)一級(jí)緩存和二級(jí)緩存

發(fā)布時(shí)間:2021-06-21 16:54:50 來源:億速云 閱讀:126 作者:Leah 欄目:大數(shù)據(jù)

Mybatis中如何實(shí)現(xiàn)一級(jí)緩存和二級(jí)緩存,針對(duì)這個(gè)問題,這篇文章詳細(xì)介紹了相對(duì)應(yīng)的分析和解答,希望可以幫助更多想解決這個(gè)問題的小伙伴找到更簡單易行的方法。

一、一級(jí)緩存

  • 一級(jí)緩存是SqlSession級(jí)別的緩存。在操作數(shù)據(jù)庫時(shí)需要構(gòu)造sqlSession對(duì)象,在對(duì)象中有一個(gè)數(shù)據(jù)結(jié)構(gòu)(HashMap)用于存儲(chǔ)緩存數(shù)據(jù)。不同的sqlSession之間的緩存數(shù)據(jù)區(qū)域(HashMap)是互相不影響的。

  • 在同一個(gè)SqlSession下的同一條查詢語句(參數(shù)也不變)會(huì)從緩存返回結(jié)果;更新語句(update、insert、delete)會(huì)刷新緩存。

二、二級(jí)緩存

  • 二級(jí)緩存是基于 mapper文件的namespace的,也就是說多個(gè)sqlSession可以共享一個(gè)mapper中的二級(jí)緩存區(qū)域,并且如果兩個(gè)mapper的namespace相同,即使是兩個(gè)mapper,那么這兩個(gè)mapper中執(zhí)行sql查詢到的數(shù)據(jù)也將存在相同的二級(jí)緩存區(qū)域中。

  • 二級(jí)緩存基于namespace。如果一個(gè)user表,有兩個(gè)不同namespace的Mapper都對(duì)其進(jìn)行查詢和更改,則互相不可見,容易讀到過期數(shù)據(jù)。

關(guān)于Mybatis中如何實(shí)現(xiàn)一級(jí)緩存和二級(jí)緩存問題的解答就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關(guān)注億速云行業(yè)資訊頻道了解更多相關(guān)知識(shí)。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI