From 8853292babb2ad94de4a3207966f1e83b767cd2d Mon Sep 17 00:00:00 2001
From: zhongrj <646384940@qq.com>
Date: Sun, 17 Sep 2023 16:38:34 +0800
Subject: [PATCH] 新增流程节点进程查询接口

---
 src/main/java/org/springblade/modules/exam/service/impl/ExamSubjectChoicesServiceImpl.java |  467 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 466 insertions(+), 1 deletions(-)

diff --git a/src/main/java/org/springblade/modules/exam/service/impl/ExamSubjectChoicesServiceImpl.java b/src/main/java/org/springblade/modules/exam/service/impl/ExamSubjectChoicesServiceImpl.java
index 4e9634d..24c8ff8 100644
--- a/src/main/java/org/springblade/modules/exam/service/impl/ExamSubjectChoicesServiceImpl.java
+++ b/src/main/java/org/springblade/modules/exam/service/impl/ExamSubjectChoicesServiceImpl.java
@@ -3,18 +3,47 @@
 
 import com.baomidou.mybatisplus.core.metadata.IPage;
 import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
+import org.springblade.modules.FTP.FtpUtil;
+import org.springblade.modules.exam.entity.ExamAnswerRecord;
 import org.springblade.modules.exam.entity.ExamSubjectChoices;
+import org.springblade.modules.exam.entity.ExamSubjectOption;
+import org.springblade.modules.exam.excel.ExamSubjectExcel;
 import org.springblade.modules.exam.mapper.ExamSubjectChoicesMapper;
+import org.springblade.modules.exam.service.ExamAnswerRecordService;
 import org.springblade.modules.exam.service.ExamSubjectChoicesService;
+import org.springblade.modules.exam.service.ExamSubjectOptionService;
 import org.springblade.modules.exam.vo.ExamSubjectChoicesVO;
+import org.springblade.modules.simulateexam.entity.SimulateExamAnswerRecord;
+import org.springblade.modules.simulateexam.service.SimulateExamAnswerRecordService;
+import org.springblade.modules.system.service.MyAsyncService;
+import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.stereotype.Service;
+import org.springframework.transaction.annotation.Transactional;
+
+import java.text.SimpleDateFormat;
+import java.util.Arrays;
+import java.util.Date;
+import java.util.List;
 
 /**
  * 选择题服务实现类
+ *
  * @author zhongrj
  */
 @Service
 public class ExamSubjectChoicesServiceImpl extends ServiceImpl<ExamSubjectChoicesMapper, ExamSubjectChoices> implements ExamSubjectChoicesService {
+
+	@Autowired
+	private ExamSubjectOptionService examSubjectOptionService;
+
+	@Autowired
+	private ExamAnswerRecordService examAnswerRecordService;
+
+	@Autowired
+	private SimulateExamAnswerRecordService simulateExamAnswerRecordService;
+	@Autowired
+	private MyAsyncService myAsyncService;
+
 
 	@Override
 	public IPage<ExamSubjectChoicesVO> selectExamSubjectChoicesPage(IPage<ExamSubjectChoicesVO> page, ExamSubjectChoicesVO examSubjectChoices) {
@@ -28,6 +57,7 @@
 
 	/**
 	 * 详情
+	 *
 	 * @param examSubjectChoices 选择题信息对象
 	 */
 	@Override
@@ -37,6 +67,441 @@
 
 	@Override
 	public boolean updateChoicesValue(String id, String value) {
-		return baseMapper.updateChoicesValue(id,value);
+		return baseMapper.updateChoicesValue(id, value);
+	}
+
+	/**
+	 * 新增题目及选项信息
+	 *
+	 * @param examSubjectChoices 题目信息对象
+	 * @return
+	 */
+	@Override
+	@Transactional(rollbackFor = Exception.class)
+	public boolean saveSubjectChoicesAndOption(ExamSubjectChoicesVO examSubjectChoices) {
+		boolean status = false;
+		//新增
+		if (null == examSubjectChoices.getId()) {
+			ExamSubjectChoices subjectChoices = new ExamSubjectChoices();
+			subjectChoices.setCreateDate(new Date());
+			subjectChoices.setDelFlag(0);
+			subjectChoices.setAnswer(examSubjectChoices.getAnswer());
+			if (null != examSubjectChoices.getAnalysis() && examSubjectChoices.getAnalysis() != "") {
+				subjectChoices.setAnalysis(examSubjectChoices.getAnalysis());
+			}
+			subjectChoices.setCreator(examSubjectChoices.getCreator());
+			subjectChoices.setChoicesType(examSubjectChoices.getChoicesType());
+			subjectChoices.setSubjectName(examSubjectChoices.getSubjectName());
+			subjectChoices.setScore(examSubjectChoices.getScore());
+			subjectChoices.setTktype(examSubjectChoices.getTktype());
+			//题目新增
+			status = this.save(subjectChoices);
+			//判断类型,单选,多选,实操
+			if (examSubjectChoices.getChoicesType() == 0 || examSubjectChoices.getChoicesType() == 1 || examSubjectChoices.getChoicesType() == 3) {
+				//选项新增
+				List<ExamSubjectOption> examSubjectOptions = examSubjectChoices.getExamSubjectOptions();
+				examSubjectOptions.forEach(examSubjectOption -> {
+					examSubjectOption.setSubjectChoicesId(subjectChoices.getId());
+					examSubjectOption.setCreateDate(new Date());
+					examSubjectOption.setDelFlag(0);
+					//新增
+					examSubjectOptionService.save(examSubjectOption);
+				});
+				return true;
+			}
+		} else {
+			//修改
+			ExamSubjectChoices subjectChoices = new ExamSubjectChoices();
+			subjectChoices.setId(examSubjectChoices.getId());
+			subjectChoices.setModifyDate(new Date());
+			subjectChoices.setAnswer(examSubjectChoices.getAnswer());
+			if (null != examSubjectChoices.getAnalysis() && examSubjectChoices.getAnalysis() != "") {
+				subjectChoices.setAnalysis(examSubjectChoices.getAnalysis());
+			}
+			subjectChoices.setModifier(examSubjectChoices.getCreator());
+			subjectChoices.setChoicesType(examSubjectChoices.getChoicesType());
+			subjectChoices.setSubjectName(examSubjectChoices.getSubjectName());
+			subjectChoices.setScore(examSubjectChoices.getScore());
+			subjectChoices.setTktype(examSubjectChoices.getTktype());
+			//题目修改
+			status = this.updateById(subjectChoices);
+			//判断类型,单选,多选
+			if (examSubjectChoices.getChoicesType() == 0 || examSubjectChoices.getChoicesType() == 1) {
+				//选项修改
+				List<ExamSubjectOption> examSubjectOptions = examSubjectChoices.getExamSubjectOptions();
+				examSubjectOptions.forEach(examSubjectOption -> {
+					examSubjectOption.setSubjectChoicesId(subjectChoices.getId());
+					examSubjectOption.setModifyDate(new Date());
+					examSubjectOption.setModifier(examSubjectChoices.getCreator());
+					//修改
+					examSubjectOptionService.updateById(examSubjectOption);
+				});
+				return true;
+			}
+			//实操
+			if (examSubjectChoices.getChoicesType() == 3) {
+				//先将选项删除
+				baseMapper.removeBySubjectId(examSubjectChoices.getId());
+				//选项新增
+				List<ExamSubjectOption> examSubjectOptions = examSubjectChoices.getExamSubjectOptions();
+				examSubjectOptions.forEach(examSubjectOption -> {
+					examSubjectOption.setSubjectChoicesId(subjectChoices.getId());
+					examSubjectOption.setCreateDate(new Date());
+					examSubjectOption.setDelFlag(0);
+					//新增
+					examSubjectOptionService.save(examSubjectOption);
+				});
+				return true;
+			}
+		}
+		return status;
+	}
+
+
+	/**
+	 * 题库导入
+	 *
+	 * @param data      导入数据
+	 * @param isCovered
+	 */
+	@Override
+	public void importSubject(List<ExamSubjectExcel> data, Boolean isCovered) {
+		data.forEach(examSubjectExcel -> {
+			//题目对象
+			ExamSubjectChoices subjectChoices = new ExamSubjectChoices();
+			subjectChoices.setCreateDate(new Date());
+			subjectChoices.setDelFlag(0);
+			subjectChoices.setAnswer(examSubjectExcel.getAnswer());
+			if (null != examSubjectExcel.getAnalysis() && examSubjectExcel.getAnalysis() != "") {
+				subjectChoices.setAnalysis(examSubjectExcel.getAnalysis());
+			}
+			subjectChoices.setChoicesType(examSubjectExcel.getChoicesType());
+			subjectChoices.setSubjectName(examSubjectExcel.getSubjectName());
+			subjectChoices.setScore(examSubjectExcel.getScore());
+			subjectChoices.setTktype(examSubjectExcel.getTktype());
+			//题目新增
+			this.save(subjectChoices);
+
+
+			//判断类型,单选,多选选项新增
+			if (examSubjectExcel.getChoicesType() == 0 || examSubjectExcel.getChoicesType() == 1) {
+				//A选项新增
+				ExamSubjectOption examSubjectOption = new ExamSubjectOption();
+				//选项新增
+				examSubjectOption.setSubjectChoicesId(subjectChoices.getId());
+				examSubjectOption.setCreateDate(new Date());
+				examSubjectOption.setDelFlag(0);
+				examSubjectOption.setOptionName("A");
+				examSubjectOption.setOptionContent(examSubjectExcel.getOptionContentA());
+				//新增
+				examSubjectOptionService.save(examSubjectOption);
+
+				//B选项新增
+				ExamSubjectOption examSubjectOption1 = new ExamSubjectOption();
+				//选项新增
+				examSubjectOption1.setSubjectChoicesId(subjectChoices.getId());
+				examSubjectOption1.setCreateDate(new Date());
+				examSubjectOption1.setDelFlag(0);
+				examSubjectOption1.setOptionName("B");
+				examSubjectOption1.setOptionContent(examSubjectExcel.getOptionContentB());
+				//新增
+				examSubjectOptionService.save(examSubjectOption1);
+
+				//C选项新增
+				ExamSubjectOption examSubjectOption2 = new ExamSubjectOption();
+				//选项新增
+				examSubjectOption2.setSubjectChoicesId(subjectChoices.getId());
+				examSubjectOption2.setCreateDate(new Date());
+				examSubjectOption2.setDelFlag(0);
+				examSubjectOption2.setOptionName("C");
+				examSubjectOption2.setOptionContent(examSubjectExcel.getOptionContentC());
+				//新增
+				examSubjectOptionService.save(examSubjectOption2);
+
+				//D选项新增
+				ExamSubjectOption examSubjectOption3 = new ExamSubjectOption();
+				//选项新增
+				examSubjectOption3.setSubjectChoicesId(subjectChoices.getId());
+				examSubjectOption3.setCreateDate(new Date());
+				examSubjectOption3.setDelFlag(0);
+				examSubjectOption3.setOptionName("D");
+				examSubjectOption3.setOptionContent(examSubjectExcel.getOptionContentD());
+				//新增
+				examSubjectOptionService.save(examSubjectOption3);
+			}
+
+
+			//多选选项新增
+			if (examSubjectExcel.getChoicesType() == 3) {
+				//1选项新增
+				if (null != examSubjectExcel.getOptionContentA() && examSubjectExcel.getOptionContentA() != "") {
+					ExamSubjectOption examSubjectOption = new ExamSubjectOption();
+					//选项新增
+					examSubjectOption.setSubjectChoicesId(subjectChoices.getId());
+					examSubjectOption.setCreateDate(new Date());
+					examSubjectOption.setDelFlag(0);
+					examSubjectOption.setOptionName("1");
+					examSubjectOption.setOptionContent(examSubjectExcel.getOptionContentA());
+					//新增
+					examSubjectOptionService.save(examSubjectOption);
+				}
+
+				//2选项新增
+				if (null != examSubjectExcel.getOptionContentB() && examSubjectExcel.getOptionContentB() != "") {
+					ExamSubjectOption examSubjectOption1 = new ExamSubjectOption();
+					//选项新增
+					examSubjectOption1.setSubjectChoicesId(subjectChoices.getId());
+					examSubjectOption1.setCreateDate(new Date());
+					examSubjectOption1.setDelFlag(0);
+					examSubjectOption1.setOptionName("2");
+					examSubjectOption1.setOptionContent(examSubjectExcel.getOptionContentB());
+					//新增
+					examSubjectOptionService.save(examSubjectOption1);
+				}
+
+				//3选项新增
+				if (null != examSubjectExcel.getOptionContentC() && examSubjectExcel.getOptionContentC() != "") {
+					ExamSubjectOption examSubjectOption2 = new ExamSubjectOption();
+					//选项新增
+					examSubjectOption2.setSubjectChoicesId(subjectChoices.getId());
+					examSubjectOption2.setCreateDate(new Date());
+					examSubjectOption2.setDelFlag(0);
+					examSubjectOption2.setOptionName("3");
+					examSubjectOption2.setOptionContent(examSubjectExcel.getOptionContentC());
+					//新增
+					examSubjectOptionService.save(examSubjectOption2);
+				}
+
+				//4选项新增
+				if (null != examSubjectExcel.getOptionContentD() && examSubjectExcel.getOptionContentD() != "") {
+					ExamSubjectOption examSubjectOption3 = new ExamSubjectOption();
+					//选项新增
+					examSubjectOption3.setSubjectChoicesId(subjectChoices.getId());
+					examSubjectOption3.setCreateDate(new Date());
+					examSubjectOption3.setDelFlag(0);
+					examSubjectOption3.setOptionName("4");
+					examSubjectOption3.setOptionContent(examSubjectExcel.getOptionContentD());
+					//新增
+					examSubjectOptionService.save(examSubjectOption3);
+				}
+
+
+				//5选项新增
+				if (null != examSubjectExcel.getOptionContentE() && examSubjectExcel.getOptionContentE() != "") {
+					ExamSubjectOption examSubjectOption4 = new ExamSubjectOption();
+					//选项新增
+					examSubjectOption4.setSubjectChoicesId(subjectChoices.getId());
+					examSubjectOption4.setCreateDate(new Date());
+					examSubjectOption4.setDelFlag(0);
+					examSubjectOption4.setOptionName("5");
+					examSubjectOption4.setOptionContent(examSubjectExcel.getOptionContentE());
+					//新增
+					examSubjectOptionService.save(examSubjectOption4);
+				}
+			}
+		});
+
+	}
+
+
+	/**
+	 * 判断当前题目的答题结果
+	 *
+	 * @param preSubJectId 题目Id
+	 * @param preResult    提交的结果
+	 * @param scoreId      成绩id
+	 * @return
+	 */
+	@Override
+	public Integer getAnswerResult(Long preSubJectId, String preResult, Long scoreId) {
+		//查询题目信息
+		ExamSubjectChoices choices = this.getById(preSubJectId);
+		//对比答案
+		if (choices.getChoicesType() == 2 || choices.getChoicesType() == 3) {
+			//保存答题记录
+			boolean result = preResult.equals(choices.getAnswer());
+			int status = 0;
+			//判断题逻辑
+			if (result) {
+				status = 1;
+			} else {
+				status = 2;
+			}
+			//新增答题记录
+			saveExamAns(choices, preSubJectId, preResult, scoreId, result);
+			//返回
+			return status;
+		} else if (choices.getChoicesType() == 0 || choices.getChoicesType() == 1) {
+			//处理多选题的答案排序
+			String[] split = preResult.split(",");
+			StringBuilder builder = new StringBuilder();
+			for (String s : split) {
+				builder.append(s);
+			}
+			char[] arrayCh = builder.toString().toCharArray();
+			//利用数组帮助类自动排序
+			Arrays.sort(arrayCh);
+			String sub0 = Arrays.toString(arrayCh);
+			String sub = sub0.substring(1, sub0.length() - 1).replaceAll(" ", "");
+
+			//保存答题记录
+			boolean result = sub.equals(choices.getAnswer());
+			int status = 0;
+			//判断题逻辑
+			if (result) {
+				status = 1;
+			} else {
+				status = 2;
+			}
+			//新增答题记录
+			saveExamAns(choices, preSubJectId, preResult, scoreId, result);
+			//返回
+			return status;
+		}
+		return 2;
+	}
+
+	/**
+	 * 新增答题记录
+	 *
+	 * @param choices      题目
+	 * @param preSubJectId 上一题题目id
+	 * @param preResult    上一题答题结果
+	 * @param scoreId      成绩 id
+	 * @param result       答题是否正确
+	 */
+	private void saveExamAns(ExamSubjectChoices choices, Long preSubJectId, String preResult, Long scoreId, boolean result) {
+		ExamAnswerRecord examAnswerRecord = new ExamAnswerRecord();
+		examAnswerRecord.setScoreId(scoreId);
+		examAnswerRecord.setAnswerOption(preResult);
+		examAnswerRecord.setSubjectChoicesId(preSubJectId);
+		examAnswerRecord.setAnswer(choices.getAnswer());
+		examAnswerRecord.setSubjectChoicesType(choices.getChoicesType());
+		examAnswerRecord.setAnswerTime(new Date());
+		int status = 0;
+		//判断题逻辑
+		if (result) {
+			status = 1;
+			examAnswerRecord.setAnswerScore(choices.getScore());
+		} else {
+			status = 2;
+			examAnswerRecord.setAnswerScore(0);
+		}
+		examAnswerRecord.setAnswerResult(status);
+		//新增
+		examAnswerRecordService.save(examAnswerRecord);
+
+		//内网数据同步...
+		String s = "insert into exam_answer_record(id,subject_choices_id,subject_choices_type,answer_option,answer" +
+			",answer_time,answer_score,answer_result,score_id) " +
+			"values(" + "'" + examAnswerRecord.getId() + "'" +
+			"," + "'" + examAnswerRecord.getSubjectChoicesId() + "'" +
+			"," + "'" + examAnswerRecord.getSubjectChoicesType() + "'" +
+			"," + "'" + examAnswerRecord.getAnswerOption() + "'" +
+			"," + "'" + examAnswerRecord.getAnswer() + "'" +
+			"," + "'" + new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(examAnswerRecord.getAnswerTime()) + "'" +
+			"," + "'" + examAnswerRecord.getAnswerScore() + "'" +
+			"," + "'" + examAnswerRecord.getAnswerResult() + "'" +
+			"," + "'" + examAnswerRecord.getScoreId() + "'" + ")";
+		//FtpUtil.sqlFileUpload(s);
+		myAsyncService.dataSync(s);
+	}
+
+	/**
+	 * 随机查询题库120道
+	 *
+	 * @return
+	 */
+	@Override
+	public List<String> getExamSubjectChoicesList() {
+		return baseMapper.getExamSubjectChoicesList();
+	}
+
+	/**
+	 * 判断当前题目的答题结果
+	 *
+	 * @param preSubJectId   题目 id
+	 * @param preResult      提交的结果
+	 * @param simulateExamId 模拟考试记录 id
+	 * @return
+	 */
+	@Override
+	public Integer getAnswerResultBySimulate(Long preSubJectId, String preResult, Long simulateExamId) {
+		//查询题目信息
+		ExamSubjectChoices choices = this.getById(preSubJectId);
+		//对比答案
+		if (choices.getChoicesType() == 2 || choices.getChoicesType() == 3) {
+			//保存答题记录
+			boolean result = preResult.equals(choices.getAnswer());
+			int status = 0;
+			//判断题逻辑
+			if (result) {
+				status = 1;
+			} else {
+				status = 2;
+			}
+			//新增模拟考试答题记录
+			saveSimulateExamAns(choices, preSubJectId, preResult, simulateExamId, result);
+			//返回
+			return status;
+		} else if (choices.getChoicesType() == 0 || choices.getChoicesType() == 1) {
+			//处理多选题的答案排序
+			String[] split = preResult.split(",");
+			StringBuilder builder = new StringBuilder();
+			for (String s : split) {
+				builder.append(s);
+			}
+			char[] arrayCh = builder.toString().toCharArray();
+			//利用数组帮助类自动排序
+			Arrays.sort(arrayCh);
+			String sub0 = Arrays.toString(arrayCh);
+			String sub = sub0.substring(1, sub0.length() - 1).replaceAll(" ", "");
+
+			//保存模拟考试答题记录
+			boolean result = sub.equals(choices.getAnswer());
+			int status = 0;
+			//判断题逻辑
+			if (result) {
+				status = 1;
+			} else {
+				status = 2;
+			}
+			//新增模拟考试答题记录
+			saveSimulateExamAns(choices, preSubJectId, preResult, simulateExamId, result);
+			//返回
+			return status;
+		}
+		return 2;
+	}
+
+	/**
+	 * 新增模拟考试答题记录
+	 *
+	 * @param choices        题目信息
+	 * @param preSubJectId   题目id
+	 * @param preResult      提交的答案
+	 * @param simulateExamId 模拟考试id
+	 * @param result         答题的结果
+	 */
+	private void saveSimulateExamAns(ExamSubjectChoices choices, Long preSubJectId, String preResult, Long simulateExamId, boolean result) {
+		SimulateExamAnswerRecord simulateExamAnswerRecord = new SimulateExamAnswerRecord();
+		simulateExamAnswerRecord.setSimulateExamId(simulateExamId);
+		simulateExamAnswerRecord.setAnswerOption(preResult);
+		simulateExamAnswerRecord.setSubjectChoicesId(preSubJectId);
+		simulateExamAnswerRecord.setAnswer(choices.getAnswer());
+		simulateExamAnswerRecord.setSubjectChoicesType(choices.getChoicesType());
+		simulateExamAnswerRecord.setAnswerTime(new Date());
+		int status = 0;
+		//判断题逻辑
+		if (result) {
+			status = 1;
+			simulateExamAnswerRecord.setAnswerScore(choices.getScore());
+		} else {
+			status = 2;
+			simulateExamAnswerRecord.setAnswerScore(0);
+		}
+		simulateExamAnswerRecord.setAnswerResult(status);
+		//新增
+		simulateExamAnswerRecordService.save(simulateExamAnswerRecord);
 	}
 }

--
Gitblit v1.9.3