1、一级缓存
它指的是Mybatis中SqlSession对象的缓存。当我们执行查询之后,查询的结果会同时存入到SqlSession为我们提供一块区域中。该区域的结构是一个Map。当我们再次查询同样的数据,mybatis会先去sqlsession中查询是否有,有的话直接拿出来用。当SqlSession对象消失时,mybatis的一级缓存也就消失了。一级缓存是 SqlSession 级别的缓存,只要 SqlSession 没有 flush 或 close,它就存在。
2、一级缓存失效的原因
2.1 同一个用户使用不同的SqlSession对象导致无法看到一级缓存工作。
2.2 在一个SqlSession中使用条件查询不同一级缓存也会失效。
2.3 在一个SqlSession使用相同条件,但是,此时在查询之间进行数据修改操作会导致一级缓存失效。
2.4 在一个SqlSession使用相同查询条件此时手动刷新缓存时导致一级缓存失败。
DeptDao dao1 = session.getMapper(DeptDao.class);
Dept dept1 = dao1.findByDeptNo(10);
System.out.println("第一次查询的部门对象地址 "+dept1);
//手动刷新用户一级缓存,导致用户一级缓存原有的内容消失掉
session.clearCache();
DeptDao dao2 = session.getMapper(DeptDao.class);
Dept dept2 = dao2.findByDeptNo(10);
System.out.println("第二次查询的部门对象地址 "+dept2);
3、二级缓存
二级缓存是 mapper 映射级别的缓存,多个 SqlSession 去操作同一个 Mapper 映射的 sql 语句,多个SqlSession 可以共用二级缓存,二级缓存是跨 SqlSession 的。
3.1 Springboot整合Mybatis开启二级缓存
在对应的Mapper接口上添加@CacheNamespace注解
3.2 二级缓存注意事项
注意:当我们在使用二级缓存时,所缓存的类一定要实现 java.io.Serializable 接口,这种就可以使用序列化方式来保存对象。二级缓存中存放的内容是数据,而不是对象,内容虽然是同样的,但是存放的是数据,第二次虽然没有发起查询,但从二级缓存中获取时,会把内容封装到新的对象返回。即两次返回结果不是同一对象。