• MyBatis 包含一个非常强大的查询缓存特性,它可以非常方便地配置和定制。缓存可以极大的提升查询效率。
• MyBatis系统中默认定义了两级缓存。
• 一级 缓存和 二级缓存。
– 1、默认情况下,只有一级缓存(SqlSession级别的缓存,也称为本地缓存)开启。
– 2、二级缓存需要手动开启和配置,他是基于namespace级别的缓存。
– 3、为了提高扩展性。MyBatis定义了缓存接口Cache。我们可以通过实现Cache接口来自定义二级缓存
1、一级缓存:(本地缓存)
sqlSession级别的缓存。一级缓存是一直开启的;SqlSession级别的一个Map与数据库同一次会话期间查询到的数据会放在本地缓存中。以后如果需要获取相同的数据,直接从缓存中拿,没必要再去查询数据库;
2、二级缓存:(全局缓存)
一个会话,查询一条数据,这个数据就会被放在当前会话的一级缓存中。
如果会话关闭;一级缓存中的数据会被保存到二级缓存中;新的会话查询信息,就可以参照二级缓存中的内容。
使用步骤:
1)、开启全局二级缓存配置:<setting name="cacheEnabled" value="true"/>
2)、去mapper.xml中配置使用二级缓存:<cache></cache>
3)、我们的POJO需要实现序列化接口
注:二级缓存在 SqlSession 关闭或提交之后才会生效
3、MyBatis缓存原理图:
4、MyBatis整合第三方缓存
MyBatis定义了Cache接口方便我们进行自定义扩展,如ehcache、redis等。
具体整合第三方缓存方法步骤自行脑补