MyBatis 在 Spring Boot 中提供了一级缓存和二级缓存。一级缓存是默认开启的,而二级缓存需要手动配置。下面分别介绍这两种缓存的使用方法。
一级缓存是 SqlSession 级别的缓存,它的生命周期与 SqlSession 相同。当在同一个 SqlSession 中执行相同的查询语句时,MyBatis 会优先从一级缓存中获取结果,而不是直接从数据库查询。这样可以提高查询性能,减少与数据库的交互次数。
一级缓存的使用方法很简单,只需要在 MyBatis 的映射文件中编写相应的查询语句即可。例如:
SELECT * FROM user WHERE id = #{id}
</select>
当执行这个查询语句时,MyBatis 会自动将结果存入一级缓存。
二级缓存是全局的缓存,它的生命周期与 Spring 容器相同。当多个 SqlSession 执行相同的查询语句时,MyBatis 会优先从二级缓存中获取结果,而不是直接从数据库查询。这样可以进一步提高查询性能,减少与数据库的交互次数。
二级缓存的使用方法如下:
首先,在 MyBatis 的映射文件中添加
<mapper namespace="com.example.UserMapper">
<cache type="org.mybatis.caches.ehcache.EhCacheCache" eviction="FIFO" flushInterval="60000" size="100" readOnly="false"/>
...
</mapper>
其中,type
属性指定了缓存实现类,这里使用 EhCache;eviction
属性指定了缓存淘汰策略,这里使用先进先出(FIFO);flushInterval
属性指定了缓存刷新间隔,这里设置为 60 秒;size
属性指定了缓存大小,这里设置为 100;readOnly
属性指定了缓存是否只读,这里设置为 false。
然后,在 Spring Boot 的配置文件中添加 EhCache 的配置:
spring:
cache:
type: ehcache
ehcache:
config: classpath:ehcache.xml
最后,创建 EhCache 的配置文件 ehcache.xml
:
<ehcache xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:noNamespaceSchemaLocation="http://www.ehcache.org/ehcache.xsd"
updateCheck="false">
<diskStore path="java.io.tmpdir/ehcache" />
<defaultCache
maxElementsInMemory="100"
eternal="false"
timeToIdleSeconds="120"
timeToLiveSeconds="120"
overflowToDisk="true"
maxElementsOnDisk="10000000"
diskPersistent="false"
diskExpiryThreadIntervalSeconds="120"
memoryStoreEvictionPolicy="LRU"
/>
<cache name="com.example.UserMapper"
maxElementsInMemory="100"
eternal="false"
timeToIdleSeconds="300"
timeToLiveSeconds="600"
overflowToDisk="true"
diskPersistent="false"
diskExpiryThreadIntervalSeconds="120"
memoryStoreEvictionPolicy="LRU"
/>
</ehcache>
这样,就完成了 MyBatis 在 Spring Boot 中的二级缓存配置。当执行相同的查询语句时,MyBatis 会自动将结果存入二级缓存。