1. 缓存种类
一级缓存 SqlSession缓存默认开启)
?? ?????SqlSession关闭后(sqlSession.close()),缓存消失。
二级缓存 SqlSessionFactory缓存
????????当二级缓存开启后,同一个命名空间(namespace) 所有的操作语句,都影响着一个共同的 cache,也就是二级缓存被多个 SqlSession 共享,是一个全局的变量。当开启缓存后,数据的查询执行的流程就是 二级缓存 -> 一级缓存 -> 数据库。
2. 二级缓存的开启
第一步:在映射文件中追加二级缓存配置
<cache eviction="LRU" flushInterval="100000" readOnly="true" size="1024"/>
<!--开启本mapper的namespace下的二级缓存-->
<!--
eviction:代表的是缓存回收策略,目前MyBatis提供以下策略。
(1) LRU,最近最少使用的,一处最长时间不用的对象
(2) FIFO,先进先出,按对象进入缓存的顺序来移除他们
(3) SOFT,软引用,移除基于垃圾回收器状态和软引用规则的对象
(4) WEAK,弱引用,更积极的移除基于垃圾收集器状态和弱引用规则的对象。
这里采用的是LRU, 移除最长时间不用的对形象
flushInterval:刷新间隔时间,单位为毫秒,这里配置的是100秒刷新,如果你
不配置它,那么当SQL被执行的时候才会去刷新缓存。
size:引用数目,一个正整数,代表缓存最多可以存储多少个对象,不宜设置过
大。设置过大会导致内存溢出。这里配置的是1024个对象
readOnly:只读,意味着缓存数据只能读取而不能修改,这样设置的好处是我们
可以快速读取缓存,缺点是我们没有办法修改缓存,他的默认值是false,不允许我们修改
-->
第二步:在mybatis-config.xml中的配置文件中开启二级缓存开关
(注:新版本默认已经开启,不需要配置)
<!-- 通知 MyBatis 框架开启二级缓存 -->
<settings>
<setting name="cacheEnabled" value="true"/>
</settings>
第三步:如果某些方法不想使用二级缓存,在方法中的select标签中可以设置关闭二级缓存。
useCache="false"
3.效果展示
@Test
public void selectUser() throws IOException {
InputStream inputStream = Resources.getResourceAsStream("mybatis-config.xml");
SqlSessionFactory sqlSessionFactory=new SqlSessionFactoryBuilder().build(inputStream);
/*********************查询第一次*******************************/
SqlSession sqlSession = sqlSessionFactory.openSession();
UserDao mapper = sqlSession.getMapper(UserDao.class);
List<User> users = mapper.selectUser();
System.out.println(users);
sqlSession.commit();
sqlSession.close();
/************************************************************/
/*********************查询第二次*******************************/
SqlSession sqlSession1= sqlSessionFactory.openSession();
/**********************方式一***********************/
//通过SqlSession获取XXXDao
UserDao mapper1= sqlSession1.getMapper(UserDao.class);
//查询所有用户
List<User> users1 = mapper1.selectUser();
System.out.println(users1);
/****************************************************/
}
|