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