Mybatis的一级缓存:
Mybatis的一级缓存简单的来说是sqlSession对象的缓存,我们在操作数据库的时候,需要创建sqlSession对象,当我们查询的时候,查询的结果会存储到sqlSession提供的一块Map数据结构的区域中,类似于Guava。当我们在一次数据库访问中,执行多次查询完全相同的SQL,一级缓存就会发挥作用,就会拿出之前查询的数据,避免再次访问数据库。所以每次查询是,先判断sqlSession中是否存在,如果存在直接拿出来用。当调用sqlSession的增删改提交关闭等方法时候,就会清空一级缓存。注:mybatis的一级缓存是默认开启的。
Mybatis的二级缓存:
二级缓存是mapper级别的缓存,可以说是由mapper中的namespace进行划分的,简单的说,不同的namespace对应不同的sqlSession对象,多个sqlSession 对象进行读写删等操作就是与二级缓存的交互。也就是说多个SqlSession去操作同一个Mapper的sql语句,多个SqlSession可以共用二级缓存,二级缓存是跨SqlSession的。
二级缓存条件1:将Pojo实体类实现序列化 public class User implements Serializable {}
二级缓存条件2:开启缓存(在Mybatis的配置文件中)