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 会自动将结果存入二级缓存。