springcache使用笔记002_注释驱动的 Spring cache 按条件查询

本文介绍了Spring Cache如何通过@Cacheable的condition属性实现按条件进行缓存操作,以及如何结合SpEL表达式处理多参数的组合缓存key。此外,还探讨了@CachePut在确保方法执行的同时将结果缓存的场景,并总结了@Cacheable、@CachePut和@CacheEvict的主要作用和配置方法。

如何按照条件操作缓存

前面介绍的缓存方法,没有任何条件,即所有对 accountService 对象的 getAccountByName 方法的调用都会起动缓存效果,不管参数是什么值,如果有一个需求,就是只有账号名称的长度小于等于 4 的情况下,才做缓存,大于 4 的不使用缓存,那怎么实现呢?

@KafkaListener(topics = KafkaConfig.CALL_LIST_CHECK_TOPIC, groupId = KafkaConfig.CALL_LIST_CHECK_CONSUMER_GROUP) public void callListWithTenantProcessed(@Payload String message) { log.info("call list with tenant topic get message:{}", message); OperatorCallListVO operatorCallListVO = JSON.parseObject(message, OperatorCallListVO.class); String sourceTenantId = operatorCallListVO.getSourceTenantId(); String enterpriseTenantId = operatorCallListVO.getEnterpriseTenantId(); String callingNumber = operatorCallListVO.getCallingNumber(); String calledNumber = operatorCallListVO.getCalledNumber(); Date callTime = operatorCallListVO.getCallTime(); if (calledNumber == null || calledNumber.length() != 11) { // 对于被叫号码不是11位手机号的话单直接做失配处理 saveCallListCheckRecord(new RiskCallListCheckRecordEntity(sourceTenantId, enterpriseTenantId, callingNumber, calledNumber, callTime)); return; } // 查找当天数据 final int max = 2; for (int i = 0; i < max; i++) { // 将缓存的key向前偏移i天 下一次循环尝试匹配查询前一天的缓存话单 String key = CacheConstant.concatSoftwareCallListKey(LocalDate.now().minusDays(i).format(DateTimeFormatter.ofPattern("yyyyMMdd")), callingNumber); if (fetchSoftwareCallList(sourceTenantId, enterpriseTenantId, callingNumber, calledNumber, callTime, key)) { // 匹配成功终止循环 break; } } // 保存失配话单比对记录 saveCallListCheckRecord(new RiskCallListCheckRecordEntity(sourceTenantId, enterpriseTenantId, callingNumber, calledNumber, callTime)); } private boolean fetchSoftwareCallList(String sourceTenantId, String enterpriseTenantId, String callingNumber, String calledNumber, Date callTime, String key) { long time = callTime.getTime(); // 获取通话开始时间(毫秒) long start = time - (60 * 1000); // 根据误差值计算起始时间 long end = time + (60 * 1000); // 根据误差值计算结束时间 // 获取分值在start和end之间的话单 Set<ZSetOperations.TypedTuple<String>> typedTuples = cardRedis.getStringRedisTemplate().opsForZSet().rangeByScoreWithScores(key, start, end); if (typedTupl
03-13
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

添柴程序猿

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值