news 2026/2/26 20:11:10

基于 XXL-JOB 3.x 实现7天、15天、30天 三个时间节点的自动提醒

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
基于 XXL-JOB 3.x 实现7天、15天、30天 三个时间节点的自动提醒

数据库

数据

INSERT INTO `test3`.`overdue_record`(`id`,`business_no`,`customer_id`,`customer_name`,`customer_email`,`customer_phone`,`due_date`,`overdue_amount`,`overdue_days`,`reminded_7_days`,`reminded_15_days`,`reminded_30_days`,`status`,`create_time`,`update_time`)VALUES(1,'ORD20240101001',1001,'张三','zhangsan@example.com', '13800138000', '2025-12-20',1000.00,8,0,0,0,0,'2025-12-2816:11:22', '2025-12-2817:27:55');INSERT INTO `test3`.`overdue_record`(`id`,`business_no`,`customer_id`,`customer_name`,`customer_email`,`customer_phone`,`due_date`,`overdue_amount`,`overdue_days`,`reminded_7_days`,`reminded_15_days`,`reminded_30_days`,`status`,`create_time`,`update_time`)VALUES(2,'ORD20240101002',1002,'李四','lisi@example.com', '13800138001', '2025-12-12',2000.00,16,0,0,0,0,'2025-12-2816:11:22', '2025-12-2817:27:55');INSERT INTO `test3`.`overdue_record`(`id`,`business_no`,`customer_id`,`customer_name`,`customer_email`,`customer_phone`,`due_date`,`overdue_amount`,`overdue_days`,`reminded_7_days`,`reminded_15_days`,`reminded_30_days`,`status`,`create_time`,`update_time`)VALUES(3,'ORD20240101003',1003,'王五','wangwu@example.com', '13800138002', '2025-11-27',3000.00,31,0,0,0,0,'2025-12-2816:11:22', '2025-12-2817:27:55');

mapper

<update id="updateDueDate">UPDATE overdue_recordSEToverdue_days=DATEDIFF(CURDATE(),due_date),update_time=NOW()WHEREstatus=0</update><select id="overdueSeven"resultType="ho.entity.OverdueSevenRecord">SELECTid,business_no,customer_name,customer_email,customer_phone,due_date,overdue_amount,reminded_seven_days,reminded_fifteen_days,reminded_thirty_days,status FROM overdue_record WHERE//根据due_date查出逾期大于7天小于15天的数据DATEDIFF(CURDATE(),due_date)>=7ANDDATEDIFF(CURDATE(),due_date)&lt;15ANDstatus=0ANDreminded_seven_days=0</select>

service
调用接口推送数据

@Service@Slf4jpublicclassOverdueRecordServiceImplextendsServiceImpl<OverdueRecordMapper,OverdueRecord>implementsIOverdueRecordService{@ResourceprivateOverdueRecordMapperoverdueRecordMapper;@OverridepublicList<OverdueRecord>overDueSeven(){// 更新逾期天数overdueRecordMapper.updateDueDate();List<OverdueSevenRecord>overdueSevenRecords=overdueRecordMapper.overdueSeven();List<OverdueRecord>overdueRecords=overdueSevenRecords.stream().map(e->{OverdueRecordoverdueRecord=newOverdueRecord();BeanUtil.copyProperties(e,overdueRecord,false);returnoverdueRecord;}).collect(Collectors.toList());intsuccessCount=0;intfailCount=0;for(OverdueRecordoverdueRecord:overdueRecords){//try{// 发送提醒booleansent=this.sendReminder(overdueRecord,7);if(sent){// 标记已发送overdueRecord.setRemindedSevenDays(true);overdueRecordMapper.updateById(overdueRecord);successCount++;log.info("成功发送7天提醒,业务编号:{}",overdueRecord.getBusinessNo());}else{failCount++;log.warn("发送7天提醒失败,业务编号:{}",overdueRecord.getBusinessNo());}}catch(Exceptione){failCount++;log.error("发送7天提醒异常,业务编号:{},错误:{}",overdueRecord.getBusinessNo(),e.getMessage(),e);}}returnnull;}privatebooleansendReminder(OverdueRecordoverdueRecord,intdays){//returntrue;}}

上门面仅展示了逾期7天的,逾期15、30的也是一样的,根据数据库字段查数据,然后调用推送接口,要自动发送用@XxlJob(“xxx”)即可

逾期15的sql是

DATEDIFF(CURDATE(),due_date)>=15ANDDATEDIFF(CURDATE(),due_date)<30

逾期30的sql是

DATEDIFF(CURDATE(),due_date)>=30
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/2/25 12:24:24

Git下载慢怎么办?结合国内镜像加速PyTorch项目克隆

Git下载慢怎么办&#xff1f;结合国内镜像加速PyTorch项目克隆 在深度学习项目的日常开发中&#xff0c;你是否经历过这样的场景&#xff1a;满怀期待地打开终端&#xff0c;输入 git clone https://github.com/pytorch/pytorch.git&#xff0c;然后眼睁睁看着进度条以几KB/s的…

作者头像 李华
网站建设 2026/2/10 11:48:24

I2C总线下HID设备启动失败:代码10的完整通信流程图解说明

深入IC HID设备启动失败之谜&#xff1a;从“代码10”看通信全流程与实战调试你有没有遇到过这样的场景&#xff1f;系统上电后&#xff0c;触摸屏毫无反应。打开设备管理器&#xff0c;赫然显示&#xff1a;“此设备无法启动&#xff08;代码10&#xff09;”。再一看&#xf…

作者头像 李华
网站建设 2026/2/18 23:12:52

垃圾分类小程序毕设源码(源码+lw+部署文档+讲解等)

博主介绍&#xff1a;✌ 专注于VUE,小程序&#xff0c;安卓&#xff0c;Java,python,物联网专业&#xff0c;有18年开发经验&#xff0c;长年从事毕业指导&#xff0c;项目实战✌选取一个适合的毕业设计题目很重要。✌关注✌私信我✌具体的问题&#xff0c;我会尽力帮助你。一、…

作者头像 李华
网站建设 2026/2/21 8:13:35

打造自动化内容矩阵:用PyTorch相关标题吸引精准开发者流量

打造自动化内容矩阵&#xff1a;用PyTorch相关标题吸引精准开发者流量 在深度学习领域&#xff0c;最让人头疼的往往不是模型设计本身&#xff0c;而是环境配置——尤其是当你满怀热情打开代码编辑器&#xff0c;准备复现一篇论文时&#xff0c;却被“CUDA not available”或“…

作者头像 李华
网站建设 2026/2/26 11:05:56

二极管正向导通特性操作指南:实验测量步骤详解

二极管正向导通特性实战测量&#xff1a;从原理到实验的完整指南在电子工程的学习与实践中&#xff0c;没有哪个元件比二极管更基础、更常见。它像电路中的“单行道”&#xff0c;只允许电流在一个方向通行——这一简单却关键的行为&#xff0c;构成了整流、稳压、保护和信号整…

作者头像 李华