spring定时任务cron为每季度第一个工作日转换为cron表达式

最近系统有个需求,执行一个定时任务发送待办事项,一年有六次,分别为每季度第一个工作日、第二季度和第四季度结束后的第十个工作日,可头疼坏了
还好我们系统有个工作日表,于是思路就是先查询出每季度的第一天,然后在表里查出大于此日期的第一个工作日,然后利用cronUtil转换成cron表达式,开启定时任务就ok了。

下面附上查询季度第一天的sql

/* 本季度的第一天 */
concat(year(curdate()),'-',elt(quarter(curdate()),1,4,7,10),'-',1)
/* 下个季度的第一天 */
date_add(LAST_DAY(MAKEDATE(EXTRACT(YEAR FROM curdate()),1) + interval QUARTER(curdate())*3-1 month),interval 1 day )
/* 本半年度的第一天   我的需求是这样,你们可以自由变动*/
concat(year(curdate()),'-07-01')
/* 明年半年度的第一天 */
concat(year(date_add(curdate(),interval 1 year )),'-07-01')
/* 查询本季度第一个工作日    需要先有个工作日表哈*/
select 日期
        from 工作日表
        where 日期>=concat(year(curdate()),'-',elt(quarter(curdate()),1,4,7,10),'-',1)  and 是否为工作日=1 limit 1

查询出来的日期通过cronUtil转换成cron表达式,下面附上cronUtil

package com.ncamc.sfa.schedule.util;

import java.text.SimpleDateFormat;
import java.util.Date;

/***
 *  功能描述:日期转换cron表达式
 */
public class CronUtil {
    /***
     *  功能描述:日期转换cron表达式
     * @param date
     * @param dateFormat
     * @return
     */
    public static String formatDateByPattern(Date date, String dateFormat){
        SimpleDateFormat sdf = new SimpleDateFormat(dateFormat);
        String formatTimeStr = null;
        if (date != null) {
            formatTimeStr = sdf.format(date);
        }
        return formatTimeStr;
    }
    /***
     * @param date  : 时间点
     * @return
     */
    public static String getCron(Date  date){
        String dateFormat="ss mm HH dd MM ?";
        return formatDateByPattern(date, dateFormat);
    }
}

注意:spring的scheduled的cron不能有年份,如果需要年份,需要合并quartz来实现了

由于我的需求是每个季度的第一个工作日,有可能今年跟下一年的季度第一个工作日是不一样的,所以定时任务也不能写死,这就需要在每次定时任务执行的时候,要修改此任务的cron,也就是获取相应任务的线程id,先停止任务,然后放入新的cron重新启动任务,可以参考我写的上一篇文章。
可参考这个:
https://blog.csdn.net/success321/article/details/116985433

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

success321

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

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

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

打赏作者

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

抵扣说明:

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

余额充值