MyBatis提供了一级缓存和二级缓存,一级缓存是SqlSession级别的缓存,每个SqlSession类的实例对象中有一个数据结构(HashMap)可以存储缓存数据,不同的SqlSession的一级缓存互不影响,二级缓存是Mapper级别的缓存,多个SqlSession类的实例对象操作同一个Mapper(namespace分割)配置文件中的SQL语句,mybatis默认开启一级缓存,不开启二级缓存,二级缓存需要手动配置,其中增删改会清空缓存,一级缓存的键是hashcode+sql+输入参数+输出参数。
使用二级缓存要注意多个Mapper(不同的namespace)中配置了同样的一个表,如果一个Mapper对该表做了修改二级缓存被清空,但是另一个Mapper中的二级缓存还存在这样可能会出错,所以使用二级缓存时,需要保证该Mapper下的数据不会在其他的Mapper.xml文件中有缓存,如果无法避免这种情况,又要使用二级缓存,可以使用拦截器判断执行的SQL涉及哪些表,然后把相关表的缓存清空。