From 247cb86585a1d1894596ed18a6c93efecb992946 Mon Sep 17 00:00:00 2001 From: luohairen <3399054449@qq.com> Date: 星期四, 14 十一月 2024 10:34:27 +0800 Subject: [PATCH] 班级成绩图表分析 --- src/main/java/com/ycl/jxkg/service/impl/ExamServiceImpl.java | 35 +++++++++++++++++++++++++++++++++-- 1 files changed, 33 insertions(+), 2 deletions(-) diff --git a/src/main/java/com/ycl/jxkg/service/impl/ExamServiceImpl.java b/src/main/java/com/ycl/jxkg/service/impl/ExamServiceImpl.java index 70f5f85..fe69d1a 100644 --- a/src/main/java/com/ycl/jxkg/service/impl/ExamServiceImpl.java +++ b/src/main/java/com/ycl/jxkg/service/impl/ExamServiceImpl.java @@ -80,6 +80,7 @@ private final UserMapper userMapper; private final ExamPaperScoreMapper examPaperScoreMapper; private final ExamPaperScoreService examPaperScoreService; + private final QuestionAnswerRecordMapper questionAnswerRecordMapper; private final Producer producer; @@ -1004,10 +1005,12 @@ examPaperScore.setTotalScore(new BigDecimal(examPaperMark.getTotalScore())); examPaperScore.setJudgeUser(userId); examPaperScore.setJudgeTime(new Date()); - if (!StringUtils.isEmpty(examPaperMark.getTitleItems())) { + if (!org.springframework.util.CollectionUtils.isEmpty(examPaperMark.getTitleItems())) { examPaperScore.setPaperContent(JSON.toJSONString(examPaperMark.getTitleItems())); + // 淇濆瓨绛旈璁板綍 + this.saveQuestionAnswerRecord(examPaperMark.getUserId(), examPaperMark.getTitleItems(), examPaperMark.getExamId(), examPaperMark.getPaperId()); } - if (!StringUtils.isEmpty(examPaperMark.getNavbar())) { + if (!org.springframework.util.CollectionUtils.isEmpty(examPaperMark.getNavbar())) { examPaperScore.setNavbar(JSON.toJSONString(examPaperMark.getNavbar())); } long questionCorrect = 0; @@ -1045,6 +1048,34 @@ return Result.ok(); } + /** + * 淇濆瓨绛旈璁板綍 + * + * @param titleItems + */ + private void saveQuestionAnswerRecord(Integer studentUserId, List<PaperFixQuestionVO> titleItems, Integer examId, Integer paperId) { + // 鍒犻櫎鍘熸潵鐨勭瓟棰樿褰� + new LambdaUpdateChainWrapper<>(questionAnswerRecordMapper) + .eq(QuestionAnswerRecord::getExamId, examId) + .eq(QuestionAnswerRecord::getUserId, studentUserId).remove(); + for (PaperFixQuestionVO titleItem : titleItems) { + for (DoQuestionVO question : titleItem.getQuestionList()) { + QuestionAnswerRecord record = new QuestionAnswerRecord(); + record.setQuestionType(titleItem.getQuestionType()); + record.setUserId(studentUserId); + record.setDoRight(question.getRight()); + record.setExamId(examId); + record.setPaperId(paperId); + record.setQuestionId(question.getId()); + record.setScore(question.getScore()); + record.setUserAnswer(StringUtils.hasText(question.getAnswer()) ? question.getAnswer() : question.getAnswerList().stream().collect(Collectors.joining("銆�"))); + questionAnswerRecordMapper.insert(record); + } + } + + + } + @Override public Result monitorList(ExamQuery query) { -- Gitblit v1.8.0