溫馨提示×

溫馨提示×

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

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

Mybatis緩存的原理是什么

發(fā)布時(shí)間:2021-06-15 15:12:50 來源:億速云 閱讀:135 作者:Leah 欄目:編程語言

Mybatis緩存的原理是什么,很多新手對此不是很清楚,為了幫助大家解決這個(gè)難題,下面小編將為大家詳細(xì)講解,有這方面需求的人可以來學(xué)習(xí)下,希望你能有所收獲。

1、什么是緩存[Cache]

  • 存在內(nèi)存中的臨時(shí)數(shù)據(jù)。

  • 將用戶經(jīng)常查詢的數(shù)據(jù)放在緩存(內(nèi)存)中,用戶去查詢數(shù)據(jù)就不用從磁盤上(關(guān)系型數(shù)據(jù)庫數(shù)據(jù)文件)查詢,從緩存中查詢,從而提高查詢效率,解決了高并發(fā)系統(tǒng)的性能問題。

2、為什么要使用緩存

減少和數(shù)據(jù)庫的交互次數(shù),減少系統(tǒng)開銷,提高系統(tǒng)效率。

3、什么樣的數(shù)據(jù)需要使用緩存

經(jīng)常查詢且不易改變的數(shù)據(jù)

4、Mybatis緩存

  • MyBatis包含一個(gè)非常強(qiáng)大的查詢緩存特性,它可以非常方便地定制和配置緩存。緩存可以極大的提升查詢效率。

  • MyBatis系統(tǒng)中默認(rèn)定義了兩級緩存:一級緩存和二級緩存

    • 默認(rèn)情況下,只有一級緩存開啟。(SqlSession級別的緩存,也稱為本地緩存)

    • 二級緩存需要手動(dòng)開啟和配置,他是基于namespace級別的緩存。

    • 為了提高擴(kuò)展性,MyBatis定義了緩存接口Cache。我們可以通過實(shí)現(xiàn)Cache接口來自定義二級緩存

5、一級緩存

一級緩存也叫本地緩存:

  • 與數(shù)據(jù)庫同一次會(huì)話期間查詢到的數(shù)據(jù)會(huì)放在本地緩存中。

  • 以后如果需要獲取相同的數(shù)據(jù),直接從緩存中拿,沒必須再去查詢數(shù)據(jù)庫;

6、一級緩存失效的四種情況

  • sqlSession不同

  • sqlSession相同,查詢條件不同

  • sqlSession相同,兩次查詢之間執(zhí)行了增刪改操作!

  • sqlSession相同,手動(dòng)清除一級緩存

@Test
public void testQueryUserById(){
  SqlSession session = MybatisUtils.getSession();
  UserMapper mapper = session.getMapper(UserMapper.class);
  User user = mapper.queryUserById(1);
  System.out.println(user);
  session.clearCache();//手動(dòng)清除緩存
  User user2 = mapper.queryUserById(1);
  System.out.println(user2);
  System.out.println(user==user2);
  session.close();
}

所以說,一級緩存就是一個(gè)map

7、二級緩存

  • 二級緩存也叫全局緩存,一級緩存作用域太低了,所以誕生了二級緩存

  • 基于namespace級別的緩存,一個(gè)名稱空間,對應(yīng)一個(gè)二級緩存;

  • 工作機(jī)制

    • 一個(gè)會(huì)話查詢一條數(shù)據(jù),這個(gè)數(shù)據(jù)就會(huì)被放在當(dāng)前會(huì)話的一級緩存中;

    • 如果當(dāng)前會(huì)話關(guān)閉了,這個(gè)會(huì)話對應(yīng)的一級緩存就沒了;但是我們想要的是,會(huì)話關(guān)閉了,一級緩存中的數(shù)據(jù)被保存到二級緩存中;

    • 新的會(huì)話查詢信息,就可以從二級緩存中獲取內(nèi)容;

    • 不同的mapper查出的數(shù)據(jù)會(huì)放在自己對應(yīng)的緩存(map)中;

使用步驟:

核心配置文件

<setting name="cacheEnabled" value="true"/>

去每個(gè)mapper.xml中配置使用二級緩存,這個(gè)配置非常簡單;

方式一:

<cache/>

方式二:

<cache
 eviction="FIFO"
 flushInterval="60000"
 size="512"
 readOnly="true"/>

這個(gè)更高級的配置創(chuàng)建了一個(gè) FIFO 緩存,每隔 60 秒刷新,最多可以存儲(chǔ)結(jié)果對象或列表的 512 個(gè)引用,而且返回的對象被認(rèn)為是只讀的,因此對它們進(jìn)行修改可能會(huì)在不同線程中的調(diào)用者產(chǎn)生沖突。

8、結(jié)論

只要開啟了二級緩存,我們在同一個(gè)Mapper中的查詢,可以在二級緩存中拿到數(shù)據(jù)

查出的數(shù)據(jù)都會(huì)被默認(rèn)先放在一級緩存中

只有會(huì)話提交或者關(guān)閉以后,一級緩存中的數(shù)據(jù)才會(huì)轉(zhuǎn)到二級緩存中

原理圖:

Mybatis緩存的原理是什么

看完上述內(nèi)容是否對您有幫助呢?如果還想對相關(guān)知識(shí)有進(jìn)一步的了解或閱讀更多相關(guān)文章,請關(guān)注億速云行業(yè)資訊頻道,感謝您對億速云的支持。

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

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

AI