关于MyBatis的缓存

我们大概都有所了解MyBatis的缓存级别分为两种,一级缓存和二级缓存。

MyBatis的一级缓存是SqlSession级别的缓存,二级缓存是Mapper级别的缓存。当我们查询数据时,使用的是同一个sqlSession时,那我们使用的是一级缓存,(当我们在配置文件中配置cacheEnabled=true,开启二级缓存)我们使用 不同的sqlSession 查询 相同的 Mapper时,有可能使用的是Mapper级别的二级缓存。

所以我们查询数据时,查询的顺序应该是:Mapper级别的缓存>sqlSession级别的缓存>数据库。

 

一级缓存是Executor执行操作时会去PerpetualCache中的HashMap中根据cacheKey查询缓存。
二级缓存是使用了装饰者模式。在SqlSession对象创建Executor对象时,SqlSession会给Executor对象加一个装饰者:CachingExecutor,然后会将操作数据库的任务交给CachingExecutor,而CachingExecutor会查找二级缓存中是否有所需要的数据,有就返回,没有就再将任务交给Executor对象。

你可能感兴趣的:(关于MyBatis的缓存)