xieb
2025-01-21 bd8d88e5e984e59a5c895ec1a254e3dbae1f9f21
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");
   }
}