目录
一级缓存
mybatis是自动为我们开启一级缓存的,是在sqlSession层面做的缓存,只要保持同一个会话,则查询条件相同时,默认从缓存中获取,要验证这个非常容易,只要事务没commit则保持同一个会话,提交了则sqlSession关闭,我们可以利用这点来验证一级缓存。说练就练。
当我们开启service的事务时
当我们失效事务管理时
可以看到在没有事务管理的情况下,sqlSession断开,程序执行了两次查询。
二级缓存
二级缓存基于namespace和mapper的作用域起作用,不依赖于sqlSession,在这里我们需要对mybatis的配置进行修改,开启二级缓存设置。
首先,在spring-mybatis.xml中进行全局配置(默认开启)
<setting name="cacheEnabled" value="true"/>
在xml中还要加入如下配置
<cache eviction="FIFO" flushInterval="60000" size="512" readOnly="true"/>
接下来我们实战看一下:
可以看到,当我们失效事务并且连续查询两次时,依然只执行了一次sql查询。