使用@Cacheable 踩过的坑

public class XXX{    
@Resourceprivate XXX self;//@Cacheable通过内部调用将不会使用缓存,从Spring4.3开始可以通过注入self,再通过self内部调用即可解决
public final static String MY_KEY="my_key:";
@Cacheable(value=MY_KEY, key = "#root.target.getFormatKey(#p0,#p1)", unless="#result == null")//自定义key名称,查询结果为空则不缓存
public xXXEntity select(Date date,String str) {    return xXXdao.select(date, str);}

public String getFormatKey(Date date,String str){//生成key    return DateUtils.getFormat(date)+sourceKey;//格式化时间拼接key}
public Integer selectValue(Date date,String str) {
  xXXEntity entity = self.select(date, str);//解决内部调用不触发缓存的问题
if(entity!=null){        return entity.getValue();    }    return 0;}
}
1.解析:
value=MY_KEY -->redisz缓存中的key
生成redis中hash的key = "#root.target.getFormatKey(#p0,#p1)"  -->当前调用对象中的方法,传入第一个和第二个参数
unless="#result == null" -->查询结果为空则不缓存(不加上会缓存一个空对象,拿值就悲剧了)
2.内部调用不触发缓存方法一:https://www.cnblogs.com/cyhbyw/p/8615816.html 侵删

方法二(推荐):https://stackoverflow.com/questions/16899604/spring-cache-cacheable-not-working-while-calling-from-another-method-of-the-s/48867068#48867068
 代码中有提现,思路:注入自己,然后通过注入的实例调用自己的方法来触发缓存机制.

@Resourceprivate XXX self;//@Cacheable通过内部调用将不会使用缓存,从Spring4.3开始可以通过注入self,再通过self内部调用即可解决
@Cacheable(value=MY_KEY, key = "#root.target.getFormatKey(#p0,#p1)", unless="#result == null")//自定义key名称,查询结果为空则不缓存
public xXXEntity select(Date date,String str) {    return xXXdao.select(date, str);}
public Integer selectValue(Date date,String str) {
  xXXEntity entity = self.select(date, str);//解决内部调用不触发缓存的问题
if(entity!=null){        return entity.getValue();    }    return 0;}
  }
 
(0)

相关推荐