From 74b520065c267999e6a4cd61c8f7b0d516931f07 Mon Sep 17 00:00:00 2001 From: xiangpei <xiangpei@timesnew.cn> Date: 星期二, 11 六月 2024 11:40:33 +0800 Subject: [PATCH] 考试管理 --- src/main/resources/mapper/ExamPaperAnswerMapper.xml | 53 +++++++++++++++++++++++++++++++++++++++++++++-------- 1 files changed, 45 insertions(+), 8 deletions(-) diff --git a/src/main/resources/mapper/ExamPaperAnswerMapper.xml b/src/main/resources/mapper/ExamPaperAnswerMapper.xml index dd8488a..7a18975 100644 --- a/src/main/resources/mapper/ExamPaperAnswerMapper.xml +++ b/src/main/resources/mapper/ExamPaperAnswerMapper.xml @@ -1,7 +1,7 @@ <?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> <mapper namespace="com.ycl.jxkg.mapper.ExamPaperAnswerMapper"> - <resultMap id="BaseResultMap" type="com.ycl.jxkg.domain.ExamPaperAnswer"> + <resultMap id="BaseResultMap" type="com.ycl.jxkg.domain.entity.ExamPaperAnswer"> <id column="id" jdbcType="INTEGER" property="id"/> <result column="exam_paper_id" jdbcType="INTEGER" property="examPaperId"/> <result column="paper_name" jdbcType="VARCHAR" property="paperName"/> @@ -26,7 +26,7 @@ </sql> <select id="studentPage" resultMap="BaseResultMap" - parameterType="com.ycl.jxkg.vo.student.exampaper.ExamPaperAnswerPageVO"> + parameterType="com.ycl.jxkg.domain.vo.student.exampaper.ExamPaperAnswerPageVO"> SELECT <include refid="Base_Column_List"/> FROM t_exam_paper_answer @@ -65,16 +65,53 @@ </select> - <select id="adminPage" resultMap="BaseResultMap" - parameterType="com.ycl.jxkg.vo.admin.paper.ExamPaperAnswerPageRequestVO"> + <select id="adminPage" resultType="com.ycl.jxkg.domain.vo.student.exampaper.ExamPaperAnswerPageResponseVO"> SELECT - <include refid="Base_Column_List"/> - FROM t_exam_paper_answer + a.id , exam_paper_id, paper_name, paper_type, system_score, user_score DIV 10 AS userScore, paper_score DIV 10 AS paperScore, + question_correct, question_count, do_time, a.status, create_user, a.create_time, b.real_name AS userName + FROM t_exam_paper_answer a + LEFT JOIN t_user b ON a.create_user = b.id <where> - <if test="subjectId != null"> - and subject_id = #{subjectId} + <if test="examPaperId != null"> + AND exam_paper_id = #{examPaperId} + </if> + <if test="userName != null and userName != ''"> + AND INSTR(b.real_name, #{userName}) </if> </where> </select> + <select id="pageExamPaper" resultType="com.ycl.jxkg.domain.vo.student.exampaper.ExamPaperAnswerPageResponseVO"> + SELECT + a.id, + a.name AS paperName, + a.score DIV 10 AS systemScore, + a.question_count, + a.subject_id, + a.paper_type, + a.suggest_time, + b.name AS subjectName, + c.real_name AS userName, + IFNULL(COUNT(d.id), 0) AS personAnswerNum, + IFNULL(COUNT(f.id), 0) AS personTotalNum + FROM t_exam_paper a + LEFT JOIN t_subject b ON a.subject_id = b.id + LEFT JOIN t_user c ON a.create_user = c.id + LEFT JOIN t_exam_paper_answer d ON a.id = d.exam_paper_id + LEFT JOIN t_exam_paper_classes e ON a.id = e.exam_paper_id + LEFT JOIN t_classes_user f ON e.classes_id = f.classes_id + <where> + a.deleted = 0 + <if test="subjectId != null and subjectId.size() > 0"> + AND a.subject_id IN + <foreach collection="subjectId" item="item" open="(" separator="," close=")">#{item}</foreach> + </if> + <if test="name != null and name != ''"> + AND INSTR(a.name, #{name}) + </if> + </where> + GROUP BY a.id + ORDER BY a.id DESC + </select> + </mapper> -- Gitblit v1.8.0