Spring的定时任务(@Scheduled注解)

但愿人长久,千里共婵娟。

主要思路

利用Spring提供@Scheduled注解完成定时任务。
(整个项目架构为Spring+Spring Boot)

代码实现

package com.xxx.xxx.xxx.timingexecution;

import org.springframework.scheduling.annotation.EnableScheduling;
import org.springframework.scheduling.annotation.Scheduled;
import org.springframework.stereotype.Component;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.Statement;
@EnableScheduling
@Component
public class ScheduledDeletion {
    //定时方法每天凌晨一点执行一次。
    @Scheduled(cron = "0 0 1 * * ?")
    public void delSomething() throws Exception{
        boolean status=false;
        Connection con = null;
        String sql;
        //url可以根据本地情况进行修改。
        String url="jdbc:mysql://XXX.com:3306/datebaseName?useUnicode=true&characterEncoding=UTF-8";
        try {
            //加载驱动。
            Class.forName("com.mysql.jdbc.Driver");
            //创建连接。
            con = DriverManager.getConnection(url,"userName","password");
            Statement stat = con.createStatement();
            //删除语句(删除30天之前数据)。
            sql = "DELETE FROM tableName WHERE DATE(create_time)<CURDATE() - INTERVAL 30 DAY";
            //查看删除是否成功。
            status=stat.execute(sql);
            if (status){
                System.out.println("删除数据成功。");
            }else {
                System.out.println("删除数据失败。");
            }
        }catch (Exception e){
            e.printStackTrace();
        }finally {
            con.close();
        }
    }
}

corn表达式示例:
(1)0 0 2 1 * ? * 表示在每月的1日的凌晨2点调整任务
  (2)0 15 10 ? * MON-FRI 表示周一到周五每天上午10:15执行。
  (3)0 15 10 ? 6L 2002-2006 表示2002-2006年的每个月的最后一个星期五上午10:15执行。
  (4)0 0 10,14,16 * * ? 每天上午10点,下午2点,4点。
  (5)0 0/30 9-17 * * ? 朝九晚五工作时间内每半小时。
  (6)0 0 12 ? * WED 表示每个星期三中午12点 。
  (7)0 0 12 * * ? 每天中午12点触发 。
  (8)0 15 10 ? * * 每天上午10:15触发 。
  (9)0 15 10 * * ? 每天上午10:15触发 。
  (10)0 15 10 * * ? * 每天上午10:15触发 。
  (11)0 15 10 * * ? 2005 2005年的每天上午10:15触发 。
  (12)0 * 14 * * ? 在每天下午2点到下午2:59期间的每1分钟触发 。
  (13)0 0/5 14 * * ? 在每天下午2点到下午2:55期间的每5分钟触发 。
  (14)0 0/5 14,18 * * ? 在每天下午2点到2:55期间和下午6点到6:55期间的每5分钟触发 。
  (15)0 0-5 14 * * ? 在每天下午2点到下午2:05期间的每1分钟触发 。
  (16)0 10,44 14 ? 3 WED 每年三月的星期三的下午2:10和2:44触发 。
  (17)0 15 10 ? * MON-FRI 周一至周五的上午10:15触发
  (18)0 15 10 15 * ? 每月15日上午10:15触发 。
  (19)0 15 10 L * ? 每月最后一日的上午10:15触发 。
  (20)0 15 10 ? * 6L 每月的最后一个星期五上午10:15触发 。
  (21)0 15 10 ? * 6L 2002-2005 2002年至2005年的每月的最后一个星期五上午10:15触发 。
  (22)0 15 10 ? * 6#3 每月的第三个星期五上午10:15触发。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值