一、一级缓存
1.介绍
MyBatis的一级缓存是SqlSession级别的,当使用同一个SqlSession进行相同的查询操作时,第一次的查询数据会被缓存,后面的查询操作会从缓存中进行数据获取,并不会访问数据库。一级缓存默认是开启的。
2.一级缓存失效的四种情况:
- 使用的不是用一个SqlSession
- 两次查询的条件不同
- 两次查询操作中进行增删改操作
- 手动清除了缓存,
sqlSession.clearCache()
二、二级缓存
1.介绍
MyBatis的二级缓存是SqlSessionFactory级别的,即通过同一个SqlSessionFactory所获取SqlSession对象查询的数据会被缓存,再通过同一个SqlSessionFactory所获取的SqlSession查询相同的数据会从缓存中获取。二级缓存默认是关闭的,需要满足以下条件才能开启。
2.二级缓存开启的条件
- 在核心配置文件中,设置全局配置属性cacheEnabled=“true”,默认为true,不需要设置
- 在映射文件中设置标签
<cache/>
- 二级缓存必须在SqlSession关闭或提交之后有效
- 查询的数据所转换的实体类类型必须实现序列化的接口,
implements Serializable
3.二级缓存失效的一种情况:
- 两次查询操作中进行增删改操作
三、MyBatis缓存查询的顺序
- 先查询二级缓存,因为二级缓存中可能会有其他程序已经查出来的数据,可以拿来直接使用。
- 如果二级缓存没有命中(log中会生成命中率),再查询一级缓存
- 如果一级缓存也没有命中,则查询数据库
- SqlSession关闭之后,一级缓存中的数据会写入二级缓存,二级缓存中的数据更多一些
四、整合第三方缓存(针对二级缓存)
可以通过jar引入第三方的缓存