From 640ff18d2d7f4be02ddb7f8f75e899f05545eb98 Mon Sep 17 00:00:00 2001 From: puzhibing <393733352@qq.com> Date: 星期一, 05 二月 2024 11:56:52 +0800 Subject: [PATCH] 更新bug修改 --- cloud-server-other/src/main/java/com/dsh/other/util/TaskUtil.java | 72 +++++++++++++++++++++++++++--------- 1 files changed, 54 insertions(+), 18 deletions(-) diff --git a/cloud-server-other/src/main/java/com/dsh/other/util/TaskUtil.java b/cloud-server-other/src/main/java/com/dsh/other/util/TaskUtil.java index e18d118..c23e459 100644 --- a/cloud-server-other/src/main/java/com/dsh/other/util/TaskUtil.java +++ b/cloud-server-other/src/main/java/com/dsh/other/util/TaskUtil.java @@ -1,13 +1,18 @@ package com.dsh.other.util; import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; +import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; import com.dsh.other.entity.SiteBooking; +import com.dsh.other.feignclient.account.StudentHonorClient; +import com.dsh.other.feignclient.account.model.StudentHonor; import com.dsh.other.mapper.SiteBookingMapper; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.scheduling.annotation.Scheduled; import org.springframework.stereotype.Component; import javax.annotation.Resource; +import java.util.Arrays; +import java.util.Calendar; import java.util.Date; import java.util.List; import java.util.concurrent.TimeUnit; @@ -22,21 +27,41 @@ @Resource private SiteBookingMapper siteBookingMapper; + @Resource + private StudentHonorClient studentHonorClient; + + + + /** * 每隔一分钟去处理的定时任务 */ //预约场地后,待支付的订单 时间超过30分钟,不保留 @Scheduled(fixedRate = 60000) - public void taskMinute(){ + public void taskMinute() { try { + Date date = new Date(); // 要增加的日期 + List<SiteBooking> siteBookings = siteBookingMapper. selectList(new LambdaQueryWrapper<SiteBooking>().eq(SiteBooking::getStatus, 0)); for (SiteBooking siteBooking : siteBookings) { - long time = siteBooking.getInsertTime().getTime(); - long l = time + 1800 * 1000; - if(System.currentTimeMillis()>l){ + + Date insert = siteBooking.getInsertTime(); + // 创建 Calendar 对象,并设置为指定的日期 + Calendar calendar = Calendar.getInstance(); + calendar.setTime(insert); + + // 增加 30 分钟 + calendar.add(Calendar.MINUTE, 30); + + // 获取增加后的日期 + Date newDate = calendar.getTime(); + +// long time = siteBooking.getInsertTime().getTime(); +// long l = time + 1800 * 1000; + if (date.after(newDate)) { siteBooking.setStatus(5); - siteBookingMapper.deleteById(siteBooking.getId()); + siteBookingMapper.updateById(siteBooking); } } //定时修改赛事状态 @@ -47,16 +72,29 @@ //预约场地后,时间超过endTime,状态变为已过期 @Scheduled(fixedRate = 60000) - public void taskMinute1(){ + public void taskMinute1() { try { List<SiteBooking> siteBookings = siteBookingMapper.selectList (new LambdaQueryWrapper<SiteBooking>().eq(SiteBooking::getStatus, 1)); for (SiteBooking siteBooking : siteBookings) { - long time = siteBooking.getEndTime().getTime(); - if (System.currentTimeMillis() > time) { - siteBooking.setStatus(4); - siteBookingMapper.updateById(siteBooking); - } + if(null == siteBooking.getEndTime()){ + continue; + } + long time = siteBooking.getEndTime().getTime(); + if (System.currentTimeMillis() > time) { + siteBooking.setStatus(4); + siteBookingMapper.updateById(siteBooking); + + //添加勋章数据 + Integer number = siteBookingMapper.selectCount(new QueryWrapper<SiteBooking>() + .eq("appUserId", siteBooking.getAppUserId()).in("status", Arrays.asList(3, 4))); + StudentHonor studentHonor = new StudentHonor(); + studentHonor.setAppUserId(siteBooking.getAppUserId()); + studentHonor.setHonorType(3); + studentHonor.setNumber(number); + studentHonorClient.saveStudentHonor(studentHonor); + + } } //定时修改赛事状态 } catch (Exception e) { @@ -66,15 +104,15 @@ // 预约场地后,待支付的订单 时间超过30分钟,不保留 @Scheduled(fixedRate = 60000) - public void taskMinute3(){ + public void taskMinute3() { try { // 获取待核销状态的记录 List<SiteBooking> siteBookings = siteBookingMapper.selectList(new LambdaQueryWrapper<SiteBooking>() - .eq(SiteBooking::getStatus, 1)); + .eq(SiteBooking::getStatus, 0).eq(SiteBooking::getState, 1)); for (SiteBooking siteBooking : siteBookings) { - long time = siteBooking.getEndTime().getTime(); - if (System.currentTimeMillis() > time) { - siteBooking.setStatus(4); + long time = siteBooking.getInsertTime().getTime(); + if (System.currentTimeMillis() > time + 1800000L) { + siteBooking.setState(3); siteBookingMapper.updateById(siteBooking); } } @@ -83,8 +121,6 @@ e.printStackTrace(); } } - - } -- Gitblit v1.7.1