1.二级缓存介绍
二级缓存:也叫全局缓存,基于namespace级别的缓存,一个namespace对应一个二级缓存。 二级缓存是mapper级别的缓存,多个SqlSession去操作同一个Mapper的sql语句,多个SqlSession可以共用二级缓存,二级缓存是跨SqlSession的。 二级缓存工作过程: 1.一个会话,查询一条数据,这个回话就会放在一级缓存中; 2.如果会话关闭,一级缓存中的数据会被保存到二级缓存中;新的会话查询信息就可以参照二级 缓存中的内容。 3.sqlsession===EmployeeMapper==>Employee DepartmentMapper==>Department 不同namespace查出的数据会放在自己对应的mapper中 效果: 数据会从二级缓存中获取,查处的数据会被默认保存在一级缓存中,只有会话提交或者关闭以后,一级缓存中的数据才会转移到二级缓存去。
2.二级缓存的使用
二级缓存的使用: 1.开启二级缓存配置: <setting name="cacheEnabled" value="true"/> 2.去每个mapper.xml中配置使用二级缓存。 <cache ></cache> 3.我们的POJO需要实现序列化接口
3.二级缓存工作过程图
4.代码实现
在全局配置文件中开启二级缓存配置
<setting name="cacheEnabled" value="true"/>
在mapper.xml文件中进行设置:
<cache eviction="FIFO" flushInterval="60000" readOnly="false" size="1024" ></cache>
<!--eviction:缓存的回收策略。①LRU:最近最少使用的 ②FIFO ③SPFT软引用 ④WEAK 弱引用 默认的是LRU
flushInterval :缓存刷新间隔。默认是不清空,单位是:毫秒
readOnly:表示缓存是否只读。true:mybatis认为从缓存中获取数据都是只读操作,
不会修改数据。mybatis为了加快获取速度,直接就会将数据在缓存中的数据交给用户。不安全,速度快。
false:非只读,mybatis认为获取的数据可能会被修改,mybatis会利用序列化&反序列化克隆一个
新的数据给你。默认是false,速度稍微那么一些。
size:表示缓存存放多少个元素。
type:指定自定义缓存的全类名。
实现Cache接口即可。
-->
POJO实现序列化接口:
public class Department implements Serializable{
private static final long serialVersionUID=1L;
测试类:
public SqlSessionFactory getSqlSessionFactory()throws IOException{
String resource="conf/conf.xml";
InputStream inputStream = MyBatisTest.class.getClassLoader().getResourceAsStream(resource);
return new SqlSessionFactoryBuilder().build(inputStream);
}
public void testSecondLevelCache() throws IOException {
SqlSessionFactory sqlSessionFactory = getSqlSessionFactory();
SqlSession openSession1 = sqlSessionFactory.openSession();
SqlSession openSession = sqlSessionFactory.openSession();
try {
EmployeeMapper mapper1 = openSession1.getMapper(EmployeeMapper.class);
EmployeeMapper mapper = openSession.getMapper(EmployeeMapper.class);
Employee empById = mapper.getEmpById(1);
System.out.println(empById);
// 只有关掉sqlsession二级缓存中才有数据。
openSession.close();
// 第二次查询是从二级缓存中拿到的数据。并没有发送新的sql.
Employee empById1 = mapper1.getEmpById(1);
System.out.println(empById1);
openSession1.close();
}finally {
}
}
关于二级缓存的一些说明:
和缓存有关的设置/属性: 1.cacheEnabled=true:表示开启缓存 cacheEnabled=false:表示关闭缓存(关闭二级缓存,一级缓存并没有关掉) 2.每个select标签都有一个useCache="true": 当是false的时候,关闭的是二级缓存。 3.每个增删改标签的 flushCache="true",增删改执行后就会清除缓存。 一级二级缓存都会被清空。查询标签默认flushCache="false" 4.sqlsession.clearCache();只是清除当前的一级缓存。 5.localCacheScope:本地缓存作用域。(影响一级缓存)本人小白,如有错误,请指正。