错误描述:
在使用二级缓存时,报的错误,如图所示:
错误解决:
mapper在映射文件中,使用<cache>元素开启当前 mapper 的namespace 下的二级缓存,如下所示:
<cache eviction="LRU" flushInterval="30000" size="512" readOnly="true"/>
这样,mapper.xml下的SQL语句执行结束后,会将结果存储到它的二级缓存中。<cache>元素配置在<mapper>元素内,<cache>元素的属性含义如下:
属性 | 描述 |
---|---|
flushInterval 属性 | 表示刷新间隔,可以设置为任意正整数,单位是毫秒。默认不设置,表示没有刷新间隔,仅仅调用语句时刷新缓存。 |
size 属性 | 表示引用数目,可以被设置为任意正整数,默认值是1024。 |
readOnly 属性 | 设置是否只读,true 表示只读,false 表示可读写。只读的缓存会给所有调用者返回缓存对象的相同实例,因此这些对象不能被修改,这提供了重要的性能优势。可读写的缓存会返回缓存对象的拷贝,这会慢一些,但是安全,因此默认值是false。 |
eviction 属性 | 表示收回策略,有 LRU、 FIFO 、SOFT 、WEAK 等策略,默认值为LRU。LRU 表示最近最少使用策略,即移除最近最少使用的对象。FIFO表示先进先出策略,按对象进入缓存的顺序来移除。SOFT 表示软引用策略,移除基于垃圾回收器状态和软引用规则的对象。WEAK 表示弱引用策略,更积极地移除基于垃圾收集器状态和弱引用的规则的对象。 |
同时也要具备一个大前提,MyBatis 默认是没有开启二级缓存,需要在 MyBatis 的配置文件 mybatis-config.xml 中开启二级缓存,配置如下:
<!-- 开启二级缓存 -->
<settings>
<setting name="cacheEnabled" value="true"/>
</settings>
需要注意的是,settings 元素要放在 properties 元素之后,typeAliases 元素之前,否则配置文件会报错。
再次执行测试类:
问题解决!