什么是缓存:
数据交换的缓冲区,当应用程序需要读取数据时,先从数据库中将数据取出,放置在缓冲区中,应用程序从缓冲区读取数据。
Mybatis一级缓存:
会话session级别的缓存,针对一次会话操作内;
一级缓存基于SqlSession,自动开启;
一级缓存的作用域是同一个SqlSession,在同一个sqlSession中两次执行相同的sql语句,第一次执行完毕会将数据库中查询的数据写到缓存(内存),第二次会从缓存中获取数据将不再从数据库查询,从而提高查询效率;
一级缓存最大的共享范围就是一个SqlSeesion内部;
当一个sqlSession结束后该sqlSession中的一级缓存也就不存在了;
Mybatis默认开启一级缓存,如果SqlSession执行了任何一次增删改操作,并且提交到数据库,MyBatis则会清空SqlSession中的一级缓存。
一级缓存失效情况:
1.不同SqlSession对应不同的一级缓存
2.同一个SqlSession单查询条件不同
3.同一个SqlSession两次查询期间执行了任何一次增删改操作
4.同一个SqlSession两次查询期间手动清空了缓存
Mybatis二级缓存:
二级缓存是mapper级别的缓存,多个SqlSession去操作同一个Mapper的sql语句;
多个SqlSession去操作数据库得到数据会存在二级缓存区域,多个SqlSession可以共用二级缓存,二级缓存是跨SqlSession的;
二级缓存是多个SqlSession共享的,其作用域是mapper的同一个namespace,不同的sqlSession两次执行相同namespace下的sql语句且向sql中传递参数也相同即最终执行相同的sql语句;
第一次执行完毕会将数据库中查询的数据写到缓存(内存),第二次会从缓存中获取数据将不再从数据库查询,从而提高查询效率;
Mybatis默认没有开启二级缓存需要在setting全局参数中配置开启二级缓存
一级缓存和二级缓存的区别:
1.一级缓存是自动开启,二级缓存是手动开启
2.一级缓存是SqlSession,二级缓存是SqlSessionFactory工厂
3.一级缓存将数据放在缓存(内存),二级缓存将数据序列化放在磁盘上