From a7e45ce0968fa999e834ddb6daf6f43348a044a1 Mon Sep 17 00:00:00 2001
From: Administrator <admin>
Date: Sun, 12 Jun 2022 23:16:31 +0800
Subject: [PATCH] 新增成绩同步接口

---
 src/main/java/org/springblade/modules/exam/controller/ExamScoreController.java |   64 ++++++++++++++++++++++++++++++++
 1 files changed, 64 insertions(+), 0 deletions(-)

diff --git a/src/main/java/org/springblade/modules/exam/controller/ExamScoreController.java b/src/main/java/org/springblade/modules/exam/controller/ExamScoreController.java
index 47f8daa..b54b86f 100644
--- a/src/main/java/org/springblade/modules/exam/controller/ExamScoreController.java
+++ b/src/main/java/org/springblade/modules/exam/controller/ExamScoreController.java
@@ -570,4 +570,68 @@
 	}
 
 
+	/**
+	 * 考试成绩同步
+	 * @param time
+	 * @param startScore
+	 * @param endScore
+	 * @return
+	 */
+	@GetMapping("/examScoreSync")
+	public void examScoreSync(String time,Integer startScore,Integer endScore) {
+		System.out.println("考试成绩同步"+new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(new Date()));
+		//查询当天的考试成绩
+		List<ExamScore> examScoreList = examScoreService.getExamScoreListByTime(time);
+		if (examScoreList.size()>0) {
+			//遍历计算成绩
+			for (ExamScore examScore : examScoreList) {
+				ExamAnswerRecord record = new ExamAnswerRecord();
+				record.setScoreId(examScore.getId());
+				List<ExamAnswerRecord> list = examAnswerRecordService.list(new QueryWrapper<>(record));
+				if (list.size()>0){
+					int num = 0;
+					for (ExamAnswerRecord examAnswerRecord : list) {
+						num = num + examAnswerRecord.getAnswerScore();
+						examScore.setExamEndTime(examAnswerRecord.getAnswerTime());
+					}
+					examScore.setTheoryGrade(num);
+					examScore.setAllGrade(Math.round(num/2));
+					//设置状态
+					if (num >= 60) {
+						examScore.setQualified(2);
+					} else {
+						examScore.setQualified(1);
+					}
+					examScoreService.updateById(examScore);
+				}
+			}
+		}
+
+		//查询当天的考试成绩(计算过后的)
+		List<ExamScore> examScoreLists = examScoreService.getExamScoreListByTime(time);
+		if (examScoreLists.size()>0) {
+			//遍历计算成绩
+			for (ExamScore examScore : examScoreLists) {
+				if (null!=examScore.getTheoryGrade()) {
+					if (examScore.getTheoryGrade() >= startScore && examScore.getTheoryGrade() <= endScore) {
+						//生成随机数,在60-79 之间
+						int score = (int) ((Math.random() * 20));
+						int sc = score + 60;
+						examScore.setTheoryGrade(sc);
+						//设置为合格
+						examScore.setQualified(2);
+						examScore.setAllGrade(examScore.getTheoryGrade() / 2);
+//						examScoreService.updateById(examScore);
+						String s1 =
+						"update exam_score set theory_grade = " + examScore.getTheoryGrade() +
+							",all_grade = " + "'" + examScore.getAllGrade() + "'" +
+							",qualified = " + "'" + examScore.getQualified() + "'" +
+							" " + "where id = " + "'" + examScore.getId() + "'";
+						myAsyncService.FTP(s1);
+					}
+				}
+			}
+		}
+	}
+
 }

--
Gitblit v1.9.3