MyBatis一级缓存和二级缓存以及 mybatis架构
缓存
数据缓存,让数据离我们执行的程序更近一点,让程序能够快速的获取到数据
缓存的作用就是减轻数据库的压力,提高查询性能。缓存实现的原理是从数据库中查询出来的对象在使用完后不要销毁,而是存储在内内(缓存)中,当再次需要获取该对象时,直接从缓存中直接获取,不再向数据库只是select语句,从而减少数据库的查询压力
mybatis一级缓存
一级缓存默认是SqlSession级别的,在每一个SqlSession中查询到的数据先缓存在SqlSession对象中,第二次查询时,先从缓存中查询,如果有直接返回,没有则查询数据库
必须是同一个SqlSession查询,SqlSession没有关闭的状态下
@Test public void test5() { //一级缓存测试 SqlSession sqlSession = MybatisUtil.getSqlSession(); TeacherDao teacherDao = sqlSession.getMapper(TeacherDao.class); Teacher teacher1=teacherDao.findTeacherById(4); System.out.println(teacher1); Teacher teacher2=teacherDao.findTeacherById(4); System.out.println(teacher2); sqlSession.commit(); sqlSession.close(); }
一级缓存流程
一级缓存生命周期:
开始于 SqlSession的创建
如果期间执行了新增、修改、删除也会清空SqlSession对象中的缓存数据,防止脏读数据
调用sqlSession.clearCache()强制清空缓存数据
结束于SqlSession的关闭,
二级缓存
二级缓存是SqlsessionFactory级别,可以让多个SqlSession共享数据 mybatis默认没有开启二级缓存,使用时需要在mybatis配置文件中配置开启,二级缓存是 SqlSessionFactory 级别的,根据 mapper 的 namespace 划分 区域的,相同 namespace 的 mapper 查询的数据缓存在同一个区域,如果使 用 mapper 代理方法每个 mapper 的 namespace 都不同,此时可以理解为二 级缓存区域是根据 mapper 划分。
如果开启了二级缓存,当SqlSession关闭时,会将一级缓存中的数据存储到二级缓存中(也就是SqlsessionFactory中), 当其他的SqlSession就可以二级缓存中查询到之前SqlSession查询的数据。
每次查询会先从缓存区域查找,如果找不到则从数据库查询,并将查询到数 据写入缓存。Mybatis 内部存储缓存使用一个 HashMap,key 为 hashCode+sqlId+Sql 语句。value 为从查询出来映射生成的 java 对象。
开启二级缓存三个配置
1、在mybatis.xml配置 <setting name="cacheEnabled" value="true"/> false则关闭二级缓存。
2、对象序列化,将所有的 POJO 类实现序列化接口 Java.io. Serializable。
3、配置映射文件,在 Mapper 映射文件中添加<cache />,表示此 mapper 开启二级缓存 * select标签useCache="true"使用二级缓存,false关闭二级缓存。
如果期间执行了新增、修改、删除也会清空SqlSession对象中的缓存数据,防止脏读数据
mybatis架构