1. 功能说明
当需要在不影响方法执行的情况下更新缓存时,可以使用 @CachePut,也就是说,被 @CachePut 注解的缓存方法总是会执行,而且会尝试将结果放入缓存(当然,是否真的会缓存还跟一些注解参数有关,比如:unless 参数)。@CachePut 跟 @Cacheable 有相同的参数属性(但是没有 sync 属性)。@CachePut 更加适合于缓存填充,而不是方法执行流的优化。
由于与 @Cacheable 的属性基本相同,所以不再重复示例。这里重点说明一下它们的区别:
@Cacheable 的逻辑是:查找缓存 - 有就返回 -没有就执行方法体 - 将结果缓存起来;
@CachePut 的逻辑是:执行方法体 - 将结果缓存起来;
所以 @Cacheable 适用于查询数据的方法,@CachePut 适用于更新数据的方法。
2. 下面举一个例子
编写一个查询方法,使用 @Cacheable :
@Override
@Cacheable(value= {"menuById"}, key = "#id")publicMenu findById(String id) {
Menu menu= this.getById(id);if (menu != null){
System.out.println("menu.name = " +menu.getName());
}returnmenu;
}
再编写一个更新方法,使用 @CachePut :
@Override
@CachePut(value= "menuById", key = "#menu.id")publicMenu ReviseById(Menu menu) {this.updateById(menu);returnmenu;
}
请求一遍查询方法,结果在缓存中生成了数据:
然后请求一遍更新方法,提交的数据如下:
再看看缓存中的数据,已经修改了:
这就是 @CachePut 的作用了。
另外说一下:官方强烈不推荐将 @Cacheable 和 @CachePut 注解到同一个方法。