概述
- MyBatis 包含一个非常强大的查询缓存特性,它可以非常方便地配置和定制。缓存可以极大的提升查询效率。
- MyBatis系统中默认定义了两级缓存。
- 一级缓存和二级缓存。
- 默认情况下,只有一级缓存(SqlSession级别的缓存,也称为本地缓存)开启。
- 二级缓存需要手动开启和配置,他是基于namespace级别的缓存。
- 为了提高扩展性。MyBatis定义了缓存接口Cache。我们可以通过实现Cache接口来自定义二级缓存
一级缓存(本地缓存)
概念
- 与数据库同一次会话期间查询到的数据会放在本地缓存中,以后如果需要获取相同的数据,直接从缓存中拿,没必要再去查数据库
- 一级缓存默认开启,无法关闭
一级缓存失效情况
- sqlSession不同
- sqlSession相同,查询条件不同(当前一级缓存中还没有这个数据)
- sqlSession相同,但在两次查询之间执行了增删改操作(这次的增删改操作可能对当前数据有影响)
- sqlSession相同,清除缓存(sqlSession.clearCache)
二级缓存(全局缓存)
概念
- 基于namespace级别的缓存,一个namespace对应一个二级缓存
工作机制
- 一个会话如果关闭,一级缓存中的数据会被保存到二级缓存中,新的会话查询信息就可以参照二级缓存中的内容
- 只有一级缓存的会话关闭才会保存到二级缓存中
使用配置
- 在全局配置文件中开启二级缓存
<!--开启二级缓存-->
<setting name="cacheEnabled" value="true"/>
- 在mapper.xml中配置使用二级缓存
<cache></cache>
- POJO要实现序列化接口
相关的设置参数
- 在select标签中有一个参数useCache,默认为true,若为false,则该查询不使用二级缓存,否则使用。
- 增删改标签有参数flushCache参数,默认为true,执行完该操纵就清除缓存(一级、二级);查询标签中的flushCache参数默认值为false
- sqlSession.clearCache()只是清除一级缓存
使用第三方缓存
ehcache
下载地址:
https://github.com/mybatis/ehcache-cache/releases
下载的是依赖包而不是源码
三个jar包:
lib目录下两个
还有一个xml配置文件,放到根目录下
下载地址:
https://wwa.lanzoui.com/iItPopf3jhe