一:一级缓存和二级缓存简介
①、一级缓存是SqlSession级别的缓存。在操作数据库时需要构造sqlSession对象,在对象中有一个数据结构(HashMap)用于存储缓存数据。不同的sqlSession之间的缓存数据区域(HashMap)是互相不影响的。
②、二级缓存是mapper级别的缓存,多个SqlSession去操作同一个Mapper的sql语句,多个SqlSession可以共用二级缓存,二级缓存是跨SqlSession的。
写这篇文章的初衷:MyBatis二级缓存在实际工作中一般都不会使用,但是就有有些面试官一直问这个问题,所以为了这道面试题,这里专门探讨一下。
二:一级缓存
MyBatis一级缓存也称为查询缓存,是在SqlSession中保存了一个HashMap, key为SQL语句,value为查询出的结果,当一个查询操作会判断查询的语句是否在HashMap中存在,如果存在则直接取出缓存的查询结果,如果不存在就继续查询数据库然后将结果缓存起来。一级缓存又被称为 SqlSession 级别的缓存,会话缓存。一级缓存减少与数据库的交互次数从而降低数据库的压力,进而提高响应速度。MyBatis一级缓存默认是自动开启的,一级缓存是针对于单个SqlSession的,不同的SqlSession之间缓存数据HashMap是无法相互影响的。当insert、update、d