**需求:**每10分钟抽取数据库中A表和B表的数据,并按映射字段组合映射后到C表。
考虑到SpringBoot快速开发的便利,尝试使用SpringBoot来解决这一问题。后来发现,真的很简单。
首先,使用maven搭建一个SpringBoot的项目,网上有很多就不详细介绍了。后面可以单独出一篇文章。
1、写一个,SpringBoot的入口类。
@EnableScheduling
@SpringBootApplication
public class App{
public static void main(String[] args) throws Exception {
SpringApplication.run(App.class, args);
}
}
其中@SpringBootApplication
和@EnableScheduling
注解分别表示,springboot的入口注解和定时器的入口。
2、开始写定时器,有两种定时的方式。
**第一种:**定义初始的延迟时间,和下次执行的至当前时间的间隔。
@Scheduled(initialDelay = 0, fixedDelay = 1000 * 60 * 5)
public void reportCurrentTime() {
//业务逻辑
}
在所要定义的方法前加入@Scheduled
注解,initialDelay
表示第一次执行的延迟时间,fixedDelay
下次执行的至当前时间的间隔,上面的代码中表示:程序启动后立刻开始执行任务,任务完成后每10分再执行一次。
**第二种:**定义触发cron计划任务
@Scheduled(cron = "* 0/2 * * * *")
public void reportCurrentTime() {
//业务逻辑
}
Cron是一种计划任务的表达式,上面的代码中 * 表示任意,0/2 表示每2分钟。详细的讲解可以自行百度。也可以使用在线Cron表达式生成器。操作还是很简单的,需要注意SpringBoot中表达式位数为6为,多了会报错。
Cron表达式格式:
{秒数} {分钟} {小时} {日期} {月份} {年份(可为空)}。