From bd8d88e5e984e59a5c895ec1a254e3dbae1f9f21 Mon Sep 17 00:00:00 2001
From: xieb <vip_xiaobin810@163.com>
Date: Tue, 21 Jan 2025 14:55:39 +0800
Subject: [PATCH] 修复

---
 src/main/java/org/springblade/scheduled/ScheduledTasks.java |  116 ++++++++++++++++++++++++++++++++++++++++++++++++++++++----
 1 files changed, 108 insertions(+), 8 deletions(-)

diff --git a/src/main/java/org/springblade/scheduled/ScheduledTasks.java b/src/main/java/org/springblade/scheduled/ScheduledTasks.java
index b53cf97..2e640a7 100644
--- a/src/main/java/org/springblade/scheduled/ScheduledTasks.java
+++ b/src/main/java/org/springblade/scheduled/ScheduledTasks.java
@@ -29,8 +29,33 @@
 	private final IAssessmentTaskService assessmentTaskService;
 	private final IEvaluateTaskService evaluateTaskService;
 
+	/**
+	 * 考核任务根据开始时间修改状态
+	 */
+	@Scheduled(fixedRate = 1000*60*5)
+	public void assessmentDoSomething() {
+		QueryWrapper queryWrapper = new QueryWrapper();
+		queryWrapper.eq("is_assessment_ok", -1);
+		queryWrapper.le("start_time", LocalDateTime.now().format(DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss")));
+		List<AssessmentTaskEntity> assessmentTaskEntityList = assessmentTaskService.list(queryWrapper);
+		if (assessmentTaskEntityList.size() > 0) {
+			List<AssessmentTaskEntity> editList = assessmentTaskEntityList.stream()
+				.map(ate -> {
+					ate.setIsAssessmentOk(0);  // 给每个对象的属性设置新值
+					return ate;  // 返回修改后的对象
+				})
+				.collect(Collectors.toList());  // 收集流中的对象到一个新的列表中
+
+			assessmentTaskService.updateBatchById(editList);
+
+			log.info("考核任务根据开始时间修改状态,修改数量为:" + assessmentTaskEntityList.size());
+		} else
+			log.info("考核任务根据开始时间修改状态,修改数量为:0");
+	}
+
 
 	/**
+	 * 考核任务根据结束时间修改当前状态
 	 * 第一个字段(秒):0
 	 * 第二个字段(分):0
 	 * 第三个字段(小时):0
@@ -39,7 +64,7 @@
 	 * 第六个字段(星期):?(无指定)
 	 */
 //	@Scheduled(cron = "0 0 0 * * ?") // 每天的凌晨0点0分0秒执行任务
-	@Scheduled(fixedRate = 1000*60*10)
+	@Scheduled(fixedRate = 1000*60*5)
 	public void doSomething() {
 		QueryWrapper queryWrapper = new QueryWrapper();
 		queryWrapper.eq("is_assessment_ok", 0);
@@ -48,20 +73,47 @@
 		if (assessmentTaskEntityList.size() > 0) {
 			List<AssessmentTaskEntity> editList = assessmentTaskEntityList.stream()
 				.map(ate -> {
-					ate.setIsAssessmentOk(1);  // 给每个Person对象的name属性设置新值
+					ate.setIsAssessmentOk(1);  // 给每个对象的属性设置新值
 					return ate;  // 返回修改后的对象
 				})
 				.collect(Collectors.toList());  // 收集流中的对象到一个新的列表中
 
 			assessmentTaskService.updateBatchById(editList);
 
-			log.info("考核任务状态修改,修改数量为:" + assessmentTaskEntityList.size());
+			log.info("考核任务根据结束时间修改当前状态,修改数量为:" + assessmentTaskEntityList.size());
 		} else
-			log.info("考核任务状态修改,修改数量为:0");
+			log.info("考核任务根据结束时间修改当前状态,修改数量为:0");
 	}
 
+	/**
+	 * 评优任务根据开始时间修改状态
+	 */
+	@Scheduled(fixedRate = 1000*60*5)
+	public void evaluateStartDoSomething() {
+		QueryWrapper queryWrapper = new QueryWrapper();
+		queryWrapper.eq("candidate_state", 0);
+		queryWrapper.le("candidate_cutoff_time_start", LocalDateTime.now().format(DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss")));
+		List<EvaluateTaskEntity> entities = evaluateTaskService.list(queryWrapper);
+		if (entities.size() > 0) {
+			List<EvaluateTaskEntity> editList = entities.stream()
+				.map(ate -> {
+					ate.setCandidateState(1);  // 给每个对象的属性设置新值
+					return ate;  // 返回修改后的对象
+				})
+				.collect(Collectors.toList());  // 收集流中的对象到一个新的列表中
+
+			evaluateTaskService.updateBatchById(editList);
+
+			log.info("评优任务根据开始时间修改状态,修改数量为:" + entities.size());
+		} else
+			log.info("评优任务根据开始时间修改状态,修改数量为:0");
+	}
+
+	/**
+	 * 评优任务根据结束时间修改状态
+	 */
 //	@Scheduled(cron = "0 10 0 * * ?") // 每天的凌晨0点10分0秒执行任务
-	@Scheduled(fixedRate = 1000*60*10)
+	@Scheduled(fixedRate = 1000*60*5)
 	public void evaluateDoSomething() {
 		QueryWrapper queryWrapper = new QueryWrapper();
 		queryWrapper.eq("candidate_state", 1);
@@ -70,16 +122,64 @@
 		if (entities.size() > 0) {
 			List<EvaluateTaskEntity> editList = entities.stream()
 				.map(ate -> {
-					ate.setCandidateState(2);  // 给每个Person对象的name属性设置新值
+					ate.setCandidateState(2);  // 给每个对象的属性设置新值
 					return ate;  // 返回修改后的对象
 				})
 				.collect(Collectors.toList());  // 收集流中的对象到一个新的列表中
 
 			evaluateTaskService.updateBatchById(editList);
 
-			log.info("考核任务状态修改,修改数量为:" + entities.size());
+			log.info("评优任务根据结束时间修改状态,修改数量为:" + entities.size());
 		} else
-			log.info("考核任务状态修改,修改数量为:0");
+			log.info("评优任务根据结束时间修改状态,修改数量为:0");
+	}
+
+	/**
+	 * 最终评优任务根据开始时间修改状态
+	 */
+	@Scheduled(fixedRate = 1000*60*5)
+	public void evaluateFinallyStartDoSomething() {
+		QueryWrapper queryWrapper = new QueryWrapper();
+		queryWrapper.eq("evaluate_state", 0);
+		queryWrapper.le("evaluate_cutoff_time_start", LocalDateTime.now().format(DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss")));
+		List<EvaluateTaskEntity> entities = evaluateTaskService.list(queryWrapper);
+		if (entities.size() > 0) {
+			List<EvaluateTaskEntity> editList = entities.stream()
+				.map(ate -> {
+					ate.setEvaluateState(1);  // 给每个对象的属性设置新值
+					return ate;  // 返回修改后的对象
+				})
+				.collect(Collectors.toList());  // 收集流中的对象到一个新的列表中
+
+			evaluateTaskService.updateBatchById(editList);
+
+			log.info("最终评优任务根据开始时间修改状态,修改数量为:" + entities.size());
+		} else
+			log.info("最终评优任务根据开始时间修改状态,修改数量为:0");
+	}
+
+	/**
+	 * 最终评优任务根据结束时间修改状态
+	 */
+	@Scheduled(fixedRate = 1000*60*5)
+	public void evaluateFinallyEndDoSomething() {
+		QueryWrapper queryWrapper = new QueryWrapper();
+		queryWrapper.eq("evaluate_state", 1);
+		queryWrapper.lt("evaluate_cutoff_time_end", LocalDateTime.now().format(DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss")));
+		List<EvaluateTaskEntity> entities = evaluateTaskService.list(queryWrapper);
+		if (entities.size() > 0) {
+			List<EvaluateTaskEntity> editList = entities.stream()
+				.map(ate -> {
+					ate.setEvaluateState(2);  // 给每个对象的属性设置新值
+					return ate;  // 返回修改后的对象
+				})
+				.collect(Collectors.toList());  // 收集流中的对象到一个新的列表中
+
+			evaluateTaskService.updateBatchById(editList);
+
+			log.info("最终评优任务根据结束时间修改状态,修改数量为:" + entities.size());
+		} else
+			log.info("最终评优任务根据结束时间修改状态,修改数量为:0");
 	}
 
 }

--
Gitblit v1.9.3