//KidsGPT定时任务 @Scheduled(cron = "00 20 0 * * *") // 秒、分、时、日期、月份、星期、年份(可省略) //@Scheduled(fixedRate = 5000) //五秒执行一次 public void processQuestionScores() { // 获取当前日期 LocalDate currentDate = LocalDate.now(); int year = currentDate.getYear(); int month = currentDate.getMonthValue(); int day = currentDate.getDayOfMonth(); // 获取题库总条数 int totalCount = regularMapper.getTotalCount(); // 遍历题目进行处理 for (int i = 1; i <= totalCount; i++) { // 查询题目 String question = regularMapper.getRegularById(i); if (!(question == null || question.isEmpty())) { try { // 计算时间 long startTime = System.currentTimeMillis(); String answer = regularImpl.getAnswerUseKnowledgeBase(question); long endTime = System.currentTimeMillis(); // 查询正确答案 String ranswer = regularMapper.getRegularModelById(String.valueOf(i)); // 查询到正确答案,继续下一步处理 if (!(ranswer == null || ranswer.isEmpty())) { // 计算分数 double score = MakeScoreUtil.calculateMeteorScore(ranswer, answer); // 得到正确分数,继续下一步处理 if (!Double.isNaN(score)) { // 保存记录 String source = "KidsGPT"; String version = year + "." + month + "." + day + "_version"; String spendTime = (endTime - startTime) + "ms"; // 计算处理时间 regularMapper.autoinsertRegular(question, answer, score, source, version, spendTime); logger.info("问题:" + i + ",保存成功"); } else { logger.info("未得到正确分数"); } } else { logger.info("未查询到正确答案"); } } catch (Exception e) { logger.error("查询题目答案时发生异常:" + e.getMessage()); } } else { logger.info("未查询到任何问题"); } } }帮我优化一下
时间: 2024-04-12 17:30:09 浏览: 123
Spring @Scheduled定时任务动态修改cron参数
4星 · 用户满意度95%
我帮你优化一下代码,主要是对循环部分进行了优化,将数据库查询操作放到循环外,减少了数据库访问次数。另外,我还对异常处理部分进行了改进,添加了更详细的错误日志记录。
```java
@Scheduled(cron = "00 20 0 * * *") // 秒、分、时、日期、月份、星期、年份(可省略)
public void processQuestionScores() {
// 获取当前日期
LocalDate currentDate = LocalDate.now();
int year = currentDate.getYear();
int month = currentDate.getMonthValue();
int day = currentDate.getDayOfMonth();
// 获取题库总条数
int totalCount = regularMapper.getTotalCount();
// 查询所有题目
List<String> questions = regularMapper.getAllRegulars();
// 遍历题目进行处理
for (int i = 0; i < questions.size(); i++) {
String question = questions.get(i);
if (question != null && !question.isEmpty()) {
try {
// 计算时间
long startTime = System.currentTimeMillis();
String answer = regularImpl.getAnswerUseKnowledgeBase(question);
long endTime = System.currentTimeMillis();
// 查询正确答案
String ranswer = regularMapper.getRegularModelById(String.valueOf(i + 1));
// 查询到正确答案,继续下一步处理
if (ranswer != null && !ranswer.isEmpty()) {
// 计算分数
double score = MakeScoreUtil.calculateMeteorScore(ranswer, answer);
// 得到正确分数,继续下一步处理
if (!Double.isNaN(score)) {
// 保存记录
String source = "KidsGPT";
String version = year + "." + month + "." + day + "_version";
String spendTime = (endTime - startTime) + "ms"; // 计算处理时间
regularMapper.autoinsertRegular(question, answer, score, source, version, spendTime);
logger.info("问题:" + (i + 1) + ",保存成功");
} else {
logger.info("未得到正确分数");
}
} else {
logger.info("未查询到正确答案");
}
} catch (Exception e) {
logger.error("查询题目答案时发生异常,问题编号:" + (i + 1) + ",异常信息:" + e.getMessage(), e);
}
} else {
logger.info("未查询到任何问题");
}
}
}
```
这样优化后的代码会在循环外一次性查询所有题目,然后在循环内处理每个题目的答案,并保存记录。同时,异常处理部分也会更加详细地记录错误信息和异常堆栈。希望对你有帮助!
阅读全文