MyBatis學習教程(七)-Mybatis緩存介紹
一、MyBatis緩存介紹
正如大多數(shù)持久層框架一樣,MyBatis 同樣提供了一級緩存和二級緩存的支持
1.一級緩存:
基于PerpetualCache 的 HashMap本地緩存,其存儲作用域為 Session,當 Session flush 或 close 之后,該Session中的所有 Cache 就將清空?!?/p>
2. 二級緩存:
二級緩存與一級緩存其機制相同,默認也是采用 PerpetualCache,HashMap存儲,不同在于其存儲作用域為 Mapper(Namespace),并且可自定義存儲源,如 Ehcache。
3. 對于緩存數(shù)據(jù)更新機制,當某一個作用域(一級緩存Session/二級緩存Namespaces)的進行了 C/U/D 操作后,默認該作用域下所有 select 中的緩存將被clear。
1.1、Mybatis一級緩存測試
package me.gacl.test;
import me.gacl.domain.User;
import me.gacl.util.MyBatisUtil;
import org.apache.ibatis.session.SqlSession;
import org.junit.Test;
/**
* @author gacl
* 測試一級緩存
*/
public class TestOneLevelCache {
/*
* 一級緩存: 也就Session級的緩存(默認開啟)
*/
@Test
public void testCache() {
SqlSession session = MyBatisUtil.getSqlSession();
String statement = "me.gacl.mapping.userMapper.getUser";
User user = session.selectOne(statement, );
System.out.println(user);
/*
* 一級緩存默認就會被使用
*/
user = session.selectOne(statement, );
System.out.println(user);
session.close();
/*
. 必須是同一個Session,如果session對象已經(jīng)close()過了就不可能用了
*/
session = MyBatisUtil.getSqlSession();
user = session.selectOne(statement, );
System.out.println(user);
/*
. 查詢條件是一樣的
*/
user = session.selectOne(statement, );
System.out.println(user);
/*
. 沒有執(zhí)行過session.clearCache()清理緩存
*/
//session.clearCache();
user = session.selectOne(statement, );
System.out.println(user);
/*
. 沒有執(zhí)行過增刪改的操作(這些操作都會清理緩存)
*/
session.update("me.gacl.mapping.userMapper.updateUser",
new User(, "user", ));
user = session.selectOne(statement, );
System.out.println(user);
}
}
1.2、Mybatis二級緩存測試
1、開啟二級緩存,在userMapper.xml文件中添加如下配置
<mapper namespace="me.gacl.mapping.userMapper"> <!-- 開啟二級緩存 --> <cache/>
2、測試二級緩存
package me.gacl.test;
import me.gacl.domain.User;
import me.gacl.util.MyBatisUtil;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.junit.Test;
/**
* @author gacl
* 測試二級緩存
*/
public class TestTwoLevelCache {
/*
* 測試二級緩存
* 使用兩個不同的SqlSession對象去執(zhí)行相同查詢條件的查詢,第二次查詢時不會再發(fā)送SQL語句,而是直接從緩存中取出數(shù)據(jù)
*/
@Test
public void testCache() {
String statement = "me.gacl.mapping.userMapper.getUser";
SqlSessionFactory factory = MyBatisUtil.getSqlSessionFactory();
//開啟兩個不同的SqlSession
SqlSession session = factory.openSession();
SqlSession session = factory.openSession();
//使用二級緩存時,User類必須實現(xiàn)一個Serializable接口===> User implements Serializable
User user = session.selectOne(statement, );
session.commit();//不懂為啥,這個地方一定要提交事務之后二級緩存才會起作用
System.out.println("user="+user);
//由于使用的是兩個不同的SqlSession對象,所以即使查詢條件相同,一級緩存也不會開啟使用
user = session.selectOne(statement, );
//session.commit();
System.out.println("user="+user);
}
}
1.3、二級緩存補充說明
1. 映射語句文件中的所有select語句將會被緩存。
2. 映射語句文件中的所有insert,update和delete語句會刷新緩存。
3. 緩存會使用Least Recently Used(LRU,最近最少使用的)算法來收回。
4. 緩存會根據(jù)指定的時間間隔來刷新。
5. 緩存會存儲1024個對象
cache標簽常用屬性:
<cache eviction="FIFO" <!--回收策略為先進先出--> flushInterval="60000" <!--自動刷新時間60s--> size="512" <!--最多緩存512個引用對象--> readOnly="true"/> <!--只讀-->
給大家補充點知識:
和hibernate一樣,mybatis也有緩存機制
一級緩存是基于 PerpetualCache(mybatis自帶)的 HashMap 本地緩存,作用范圍為session,所以當session commit或close后,緩存就會被清空
二級緩存默認也是基于 PerpetualCache,但是可以為其制定存儲源,比如ehcache
一級緩存緩存的是SQL語句,而二級緩存緩存的是結(jié)果對象,看如下例子(mybatis的日志級別設為debug)
相關文章
elasticsearch節(jié)點間通信的基礎transport啟動過程
這篇文章主要為大家介紹了elasticsearch節(jié)點間通信的基礎transport啟動過程,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-04-04
MyBatis中動態(tài)SQL語句@Provider的用法
本文主要介紹了MyBatis中動態(tài)SQL語句@Provider的用法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2023-06-06
詳解springboot + profile(不同環(huán)境讀取不同配置)
本篇文章主要介紹了springboot + profile(不同環(huán)境讀取不同配置),具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-05-05
Java并發(fā)編程ArrayBlockingQueue的使用
ArrayBlockingQueue是一個備受矚目的有界阻塞隊列,本文將全面深入地介紹ArrayBlockingQueue的內(nèi)部機制、使用場景以及最佳實踐,感興趣的可以了解一下2024-08-08
Spring Data JPA踩坑記錄(@id @GeneratedValue)
這篇文章主要介紹了Spring Data JPA踩坑記錄(@id @GeneratedValue),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-07-07

