目录
一、缓存的适用性
适合使用缓存: 经常查询并且不经常改变的数据,数据的正确与否对最终结果影响不大的,比如:一个公司的介绍,新闻等。
二、什么是 MyBatis 缓存
功能:减少 Java Application 与数据库的交互次数,从而提升程序的运行效率;
1、MyBatis 缓存的分类
- 一级缓存
- 二级缓存
- 自定义缓存
三、一级缓存
它指的是Mybatis中SqlSession对象的缓存,当我们执行查询以后,查询的结果会同时存入到SqlSession为我们提供的一块区域中,该区域的结构是一个Map,当我们再次查询同样的数据,Mybatis会先去SqlSession中查询是否有,的话直接拿出来用,当SqlSession对象消失时,Mybatis的一级缓存也就消失了,同时一级缓存是SqlSession范围的缓存,当调用SqlSession的修改、添加、删除、commit(),close等方法时,就会清空一级缓存。
1、一级缓存工作流程
- 对于某个 Select Statement,根据该 Statement 生成 key;
- 判断在Local Cache中,该key是否有对应的数据存在;
- 如果命中,则跳过查询数据库,继续往下走;
- 如果没命中,去数据库中查询数据, 得到查询结果;
- 将key和查询到的结果作为 key 和 value,放入Local Cache 中;
- 将查询结果返回;
- 判断缓存级别是否为 STATEMENT 级别,如果是的话,清空本地缓存;
2、一级缓存失效的情况
- 不同SqlSession对应不同的一级缓存
- 同一个SqlSession单查询条件不同
- 同一个SqlSession两次查询期间执行了任何一次增删改操作
- 同一个SqlSession两次查询期间手动清空了缓存
四、二级缓存(不建议使用)
它指的是Mybatis中SqlSessionFactory对象的缓存,由同一个SqlSessionFactory对象创建的SqlSession共享其缓存,但是其中缓存的是数据而不是对象,所以从二级缓存再次查询出得结果的对象与第一次存入的对象是不一样的。
1、二级缓存如何使用
1).xml文件配置
- 在Mybatis的主配置文件中配置;
- 让当前的映射文件支持二级缓存(在Dao.xml映射文件中配置)
- 让当前的方法支持二级缓存(在标签中配置)
2)注解配置
- 在Mybatis的主配置文件中配置;
- 在接口的定义上面直接使用@CacheNamespace 并将blocking设置为true,二级缓存就可以使用了;
2、二级缓存的优缺点
优点:Mybatis 的二级缓存相对于一级缓存来说, 实现了缓存数据的共享,可控性也更强;
缺点:
- 极大可能会出现错误数据,有设计上的缺陷, 安全使用的条件比较苛刻;
- 分布式环境下,必然会出现读取到错误数据,所以不推荐使用。
五、一级缓存,二级缓存的区别
1、作用域不同:
一级缓存:当前对象的SqlSession
二级缓存:当前SqlSessionFactory中所有的SqlSession对象
2、开启方式不同:
一级缓存:默认自动开启
二级缓存:需要主动配置,手动开启
3、缓存地址不同:
一级缓存:内存
二级缓存:磁盘
4、存储对象不同:
一级缓存:所查数据结果映射成实现类对象的地址值
二级缓存:所查数据结果映射成实现类对象序列化后的properties文件
六、自定义缓存
- 实现 org. apache. ibatis. cache. Cache 接口自定义缓存;
- 引入 Redis 等第三方内存库作为 MyBatis 缓存。
七、总结
MyBatis的一级缓存是SqlSession级别的缓存,一级缓存缓存的是对象,当SqlSession提交、关闭以及其他的更新数据库的操作发生后,一级缓存就会清空。二级缓存是SqlSessionFactory级别的缓存,同一个SqlSessionFactory产生的SqlSession都共享一个二级缓存,二级缓存中存储的是数据,当命中二级缓存时,通过存储的数据构造对象返回。当查询数据的时候,查询的流程是二级缓存>一级缓存>数据库。