SpringBoot中注解缓存 @Cacheable 及控制台展示 执行 SQL 查看是否缓存成功
SpringBoot 的maven的项目中,首先在 pom.xml文件中 注入 Spring Boot 缓存支持启动器 及 Ehcache 坐标
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-cache</artifactId>
</dependency>
<!-- Ehcache 坐标 -->
<dependency>
<groupId>net.sf.ehcache</groupId>
<artifactId>ehcache</artifactId>
</dependency>
创建 Ehcache 的配置文件,文件名:ehcache.xml 位置:src/main/resources/ehcache.xml
<diskStore path="java.io.tmpdir"/>
<defaultCache
maxElementsInMemory="10000"
eternal="false"
timeToIdleSeconds="120"
timeToLiveSeconds="120"
maxElementsOnDisk="10000000"
diskExpiryThreadIntervalSeconds="120"
memoryStoreEvictionPolicy="LRU">
<persistence strategy="localTempSwap"/>
</defaultCache>
<!-- 自定义缓存策略 -->
<cache name="student"
maxElementsInMemory="10000"
eternal="false"
timeToIdleSeconds="120"
timeToLiveSeconds="120"
maxElementsOnDisk="10000000"
diskExpiryThreadIntervalSeconds="120"
memoryStoreEvictionPolicy="LRU">
<persistence strategy="localTempSwap"/>
</cache>
创建成功后 在 application.properties 中引入创建的 缓存文件
引入: spring.cache.ehcache.cofnig=ehcache.xml ,
控制台 打印执行的 SQL 日志级别: logging.level.com.test.mapper=debug
项目目录为;
测试 缓存方法 :
指定 value =“student” ,student 为 创建文件中 自定义的缓存策略,如果不指定 @Cacheable(value=“student”),
@Cacheable 则默认的缓存策略为 ehcache.xml 文件中
持久层的 底层 测试查询方法
创建启动类 ,启用缓存 @EnableCaching
Junit 测试类
运行测试类 ,重复调用相同查询方法, 查看控制台打印SQL
重复调用,查询SQL 第一次调用 直接查询数据库表,第二次调用直接 从缓存中读取,所以 SQL 只执行了一遍