9.1 概念
-
MyBatis包含一个非常强大的查询缓存特性,它可以非常方便地定制和配置缓存。缓存可以极大的提升查询效率。
-
MyBatis系统中默认定义了两级缓存:一级缓存和二级缓存
- 默认情况下,只有一级缓存开启。(SqlSession级别的缓存,也称为本地缓存)
- 二级缓存需要手动开启和配置,他是基于namespace级别的缓存。
- 为了提高扩展性,MyBatis定义了缓存接口Cache。我们可以通过实现Cache接口来自定义二级缓存
9.2一级缓存
一级缓存:在mybatis没有做配置的情况下,默认使用一级缓存。如果SqlSession执行一次查询后,没有关闭,刷新,超时等情况下
条件相同再次查询,就直接使用缓存信息而不需要再去数据库执行SQL语句。生命周期:
- 进行一次有效查询,产生一个PerpetualCache
- 如果调用close方法,就会释放一级缓存对象PerpetualCache
- 如果调用clearCaher,就会清空PerpetualCache对象中数据,但对象SqlSession可用
- 如果执行了任何一个update(insert , update , delete),都会清空PerpetualCachel
9.3二级缓存:
-
二级缓存也叫全局缓存,一级缓存作用域太低了,所以诞生了二级缓存
-
基于namespace级别的缓存,一个名称空间,对应一个二级缓存;
-
工作机制
- 一个会话查询一条数据,这个数据就会被放在当前会话的一级缓存中;
- 如果当前会话关闭了,这个会话对应的一级缓存就没了;但是我们想要的是,会话关闭了,一级缓存中的数据被保存到二级缓存中;
- 新的会话查询信息,就可以直接从二级缓存中获取内容;
- 不同的mapper查出的数据会放在自己对应的缓存(map)中;
9.2.1二级缓存实现:
- 开启全局缓存:
<!--显示的开启全局缓存-->
<setting name="cacheEnabled" value="true"/>
9.2.2 小结
- 只要开启了二级缓存,在同一个Mapper下就有效
- 所有的数据都会先放在一级缓存中;
- 只有当会话提交,或者关闭的时候,才会提交到二级缓冲中!
以后Redis数据库来做缓存! K-V