EvaluateTask.java 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657
  1. package com.xjrsoft.module.job;
  2. import com.xjrsoft.common.mybatis.SqlRunnerAdapter;
  3. import com.xjrsoft.common.utils.DateUtils;
  4. import com.xjrsoft.common.utils.SqlRunnerAdapterUtil;
  5. import com.xjrsoft.module.evaluate.entity.EvaluateManage;
  6. import lombok.extern.slf4j.Slf4j;
  7. import org.springframework.scheduling.annotation.Scheduled;
  8. import org.springframework.stereotype.Component;
  9. import java.util.Date;
  10. import java.util.List;
  11. import java.util.Map;
  12. /**
  13. * 自动生成评价提交记录
  14. */
  15. @Component
  16. @Slf4j
  17. public class EvaluateTask {
  18. /**
  19. * 需要重复评价的,每天凌晨1点自动生成新的评价提交记录
  20. */
  21. @Scheduled(cron = "0 0 1 * * ?")
  22. public void addSubmitRecord() {
  23. System.out.printf("定时新增评价提交记录:%s", DateUtils.format(new Date(), DateUtils.DATE_TIME_PATTERN));
  24. try {
  25. //先查出所有进行中的需要重复评价的评价管理
  26. String listEvaluateManageSql = "select t.id, t.create_frequency from evaluate_manage t where t.is_auto_create = 1 and t.status = 1";
  27. List<Map<String, Object>> evaluateManageList = SqlRunnerAdapter.db().selectList(listEvaluateManageSql, EvaluateManage.class);
  28. for (Map<String, Object> evaluateManageMap : evaluateManageList) {
  29. EvaluateManage evaluateManage = SqlRunnerAdapterUtil.convertMapToEntity(evaluateManageMap, EvaluateManage.class);
  30. //TODO 根据评价的频率进行新增
  31. //默认每天新增根据评价管理id
  32. String insertSubmitScoreSql = "insert into evaluate_submit_record (id, evaluate_manage_id, evaluate_executer_id, create_date, evaluated_object, evaluated_object_id, status)" +
  33. " (SELECT" +
  34. " UUID()," +
  35. " t.evaluate_manage_id," +
  36. " t.id," +
  37. " NOW()," +
  38. " if(t2.evaluate_type='dm_evaluate_class', 'class', 'teacher')," +
  39. " t.evaluate_object_id," +
  40. " 0" +
  41. " FROM evaluate_executer t" +
  42. " LEFT JOIN evaluate_manage t1 ON (t1.id = t.evaluate_manage_id)" +
  43. " LEFT JOIN evaluate_template t2 ON (t2.id = t1.evaluate_template_id)" +
  44. " WHERE t.delete_mark = 0" +
  45. " AND t.evaluate_manage_id = " + evaluateManage.getId() + ")";
  46. SqlRunnerAdapter.db().insert(insertSubmitScoreSql);
  47. }
  48. } catch (Exception e) {
  49. log.error(e.getMessage(), "定时新增评价提交记录");
  50. }
  51. }
  52. }