每天晚上定时更新数据库中的一张表
方法一:使用quartz框架
- 导入jar包
可以在maven仓库中下载这两个jar包,然后保存到一个文件夹中,同时摁快捷键ctrl+alt+shift+s,
选中最左侧model,然后dependencies,再点+
选中1 Jars or directories,然后选中你要上传的jar包
- 编写PrintJob 类,实现Job接口
public class PrintJob implements Job {
@Override
public void execute(JobExecutionContext jobExecutionContext) throws JobExecutionException {
String printTime = new SimpleDateFormat("yy-MM-dd HH-mm-ss").format(new Date());
System.out.println("PrintWordsJob start at:" + printTime + ", prints: Hello Job-" + new Random().nextInt(100));
}
- 编写主函数,调用Print Job
public static void main(String[] args) throws SchedulerException, InterruptedException {
// 1、创建调度器Scheduler
SchedulerFactory schedulerFactory = new StdSchedulerFactory();
Scheduler scheduler = schedulerFactory.getScheduler();
// 2、创建JobDetail实例,并与PrintWordsJob类绑定(Job执行内容)
JobDetail jobDetail = JobBuilder.newJob(PrintJob.class)
.withIdentity("job1", "group1").build();
// 3、构建Trigger实例,每隔1s执行一次
Trigger trigger = TriggerBuilder.newTrigger().withIdentity("trigger1", "triggerGroup1")
.startNow()//立即生效
.withSchedule(SimpleScheduleBuilder.simpleSchedule()
.withIntervalInSeconds(1)//每隔1s执行一次
.repeatForever()).build();//一直执行
//4、执行
scheduler.scheduleJob(jobDetail, trigger);
System.out.println("--------scheduler start ! ------------");
scheduler.start();
//睡眠
TimeUnit.MINUTES.sleep(1);
scheduler.shutdown();
System.out.println("--------scheduler shutdown ! ------------");
}
方法二:使用@EnableScheduling 注解
- 创建定时任务SaticScheduleTask类
@Configuration //1.主要用于标记配置类,兼备Component的效果。
@EnableScheduling // 2.开启定时任务
public class SaticScheduleTask {
@Autowired
DaJzryxxMapper daJzryxxMapper;
//3.添加定时任务
@Scheduled(cron = "0 0 1 * * ?")
//或直接指定时间间隔,每天凌晨1点执行一次
//@Scheduled(fixedRate=5000)
private void configureTasks() {
daJzryxxMapper.updateJzryxxBy30();
}
- 编写DaJzryxxMapper及对应的sql语句:此处省略,
- @Scheduled(cron = “0 0 1 * * ?”)详解
@Scheduled注解执行定时任务,cron指计划任务,是指任务在约定时间执行已经计划好的工作,在linux中,我们经常用到cron服务器来完成这个工作,cron服务器可以更具配置文件约定的时间来执行指定的任务;cron表达式则是指配置约定时间的规则。cron 表达式自动生成.