我目前遇到的业务场景
1. 将存在redis的点赞数量,写回数据库
2. 将存在redis里面的下载数量,写回到数据库
第一、在启动类上添加注解@EnableScheduling 开启定时任务
@EnableScheduling
@SpringBootApplication
public class JavaApplication {
public static void main(String[] args) {
SpringApplication.run(JavaApplication.class, args);
}
}
第二、写一个类,标明定时时间,多久执行
@Component
public class ScheduledTask {
@Autowired
private RedisTemplate redisTemplate;
@Autowired
private ResumeMapper resumeMapper;
@Scheduled(fixedRate = 300000) //5分钟就执行一次
public void setResumeCount(){
//我想将resumeCount+id这种格式的键值,按时将值设置回数据库
//我怎么把它们取出来呢?
Set<String> keys = redisTemplate.keys("reabcbount*");
for (String key : keys){
//该键的下载数量
Integer value = (Integer)redisTemplate.opsForValue().get(key);
//简历数据的id
String substring = key.substring(11);
//更新数据库当前简历的下载次数
resumeMapper.updateResumeCount(value,Integer.valueOf(substring));
}
}
}