| | |
| | | <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> |
| | | <mapper namespace="com.ycl.jxkg.mapper.ExamPaperScoreMapper"> |
| | | <resultMap id="BaseResultMap" type="com.ycl.jxkg.domain.entity.ExamPaperScore"> |
| | | <id column="id" jdbcType="INTEGER" property="id"/> |
| | | <result column="exam_id" jdbcType="INTEGER" property="examId"/> |
| | | <result column="exam_name" jdbcType="VARCHAR" property="examName"/> |
| | | <result column="paper_type" jdbcType="INTEGER" property="paperType"/> |
| | | <result column="score" jdbcType="INTEGER" property="score"/> |
| | | <result column="total_score" jdbcType="INTEGER" property="totalScore"/> |
| | | <result column="question_correct" jdbcType="INTEGER" property="questionCorrect"/> |
| | | <result column="question_count" jdbcType="INTEGER" property="questionCount"/> |
| | | <result column="do_time" jdbcType="INTEGER" property="doTime"/> |
| | | <result column="status" jdbcType="INTEGER" property="status"/> |
| | | <result column="user_id" jdbcType="INTEGER" property="userId"/> |
| | | <result column="judge_user" jdbcType="INTEGER" property="judgeUser"/> |
| | | <result column="create_time" jdbcType="TIMESTAMP" property="createTime"/> |
| | | <result column="submit_time" jdbcType="TIMESTAMP" property="submitTime"/> |
| | | <result column="exam_id" jdbcType="INTEGER" property="examId"/> |
| | | <result column="exam_name" jdbcType="INTEGER" property="examName"/> |
| | | <result column="paper_content" jdbcType="INTEGER" property="paperContent"/> |
| | | <id column="id" property="id"/> |
| | | <result column="paper_id" property="examPaperId"/> |
| | | <result column="paper_name" property="paperName"/> |
| | | <result column="paper_type" property="paperType"/> |
| | | <result column="score" property="score"/> |
| | | <result column="total_score" property="totalScore"/> |
| | | <result column="question_correct" property="questionCorrect"/> |
| | | <result column="question_count" property="questionCount"/> |
| | | <result column="do_time" property="doTime"/> |
| | | <result column="status" property="status"/> |
| | | <result column="user_id" property="userId"/> |
| | | <result column="judge_user" property="judgeUser"/> |
| | | <result column="submit_time" property="submitTime"/> |
| | | <result column="judge_time" property="judgeTime"/> |
| | | <result column="exam_id" property="examId"/> |
| | | <result column="exam_name" property="examName"/> |
| | | <result column="paper_content" property="paperContent"/> |
| | | <result column="navbar" property="navbar"/> |
| | | </resultMap> |
| | | |
| | | <sql id="Base_Column_List"> |
| | | id, |
| | | exam_id, |
| | |
| | | <select id="studentPage" resultType="com.ycl.jxkg.domain.vo.student.exampaper.ExamPaperAnswerPageResponseVO"> |
| | | SELECT |
| | | a.*, |
| | | ep.name as paperName |
| | | ep.name AS paperName |
| | | FROM t_exam_paper_score a |
| | | INNER JOIN t_exam_paper ep ON ep.id = paper_id AND ep.deleted = 0 |
| | | <where> |
| | | and user_id = #{createUser} |
| | | AND user_id = #{createUser} |
| | | <if test="examName != null and examName != ''"> |
| | | and INSTR(exam_name, #{examName}) |
| | | AND INSTR(exam_name, #{examName}) |
| | | </if> |
| | | </where> |
| | | </select> |
| | | |
| | | |
| | | <select id="getByExamIdUserId" resultType="com.ycl.jxkg.domain.entity.ExamPaperScore"> |
| | | SELECT |
| | | <include refid="Base_Column_List"/> |
| | | from t_exam_paper_score |
| | | <where> |
| | | and user_id = #{userId} |
| | | and exam_id = #{examId} |
| | | </where> |
| | | </select> |
| | | <select id="selectAllCount" resultType="java.lang.Integer"> |
| | | SELECT count(*) |
| | | from t_exam_paper_score |
| | |
| | | </select> |
| | | |
| | | <select id="selectCountByDate" resultType="com.ycl.jxkg.domain.other.KeyValue"> |
| | | SELECT create_time as name, COUNT(create_time) as value |
| | | from (SELECT DATE_FORMAT(create_time, '%Y-%m-%d') as create_time |
| | | from t_exam_paper_score |
| | | WHERE create_time between #{startTime} and #{endTime}) a |
| | | GROUP BY create_time |
| | | SELECT submit_time as name, sum(question_count) as value |
| | | from |
| | | ( |
| | | SELECT question_count ,DATE_FORMAT(submit_time, '%Y-%m-%d') as submit_time from t_exam_paper_score |
| | | WHERE submit_time between #{startTime} and #{endTime} |
| | | ) a |
| | | GROUP BY submit_time |
| | | </select> |
| | | |
| | | |
| | |
| | | |
| | | <select id="adminPage" resultType="com.ycl.jxkg.domain.vo.student.exampaper.ExamPaperAnswerPageResponseVO"> |
| | | SELECT |
| | | a.*, b.real_name AS userName, c.name as paperName |
| | | a.id, a.exam_name, a.score, a.total_score, a.question_correct, a.question_count, a.do_time, a.status, IF(a.status = 0, a.submit_time, '缺考') AS submitTime, b.real_name AS userName, c.name AS paperName |
| | | FROM t_exam_paper_score a |
| | | INNER JOIN t_user b ON a.user_id = b.id AND b.deleted = 0 |
| | | INNER JOIN t_exam_paper c ON a.paper_id = c.id AND c.deleted = 0 |
| | | <where> |
| | | exam_id = #{examId} |
| | | <if test="examId != null and examId != ''"> |
| | | AND a.exam_id = #{examId} |
| | | </if> |
| | | <if test="userId != null and userId != ''"> |
| | | AND a.user_id = #{userId} |
| | | </if> |
| | | <if test="userName != null and userName != ''"> |
| | | AND INSTR(b.real_name, #{userName}) |
| | | </if> |
| | | <if test="examName != null and examName != ''"> |
| | | AND INSTR(a.exam_name, #{examName}) |
| | | </if> |
| | | </where> |
| | | </select> |
| | |
| | | b.name AS subjectName, |
| | | c.real_name AS userName, |
| | | IFNULL(COUNT(DISTINCT d.id), 0) AS personAnswerNum, |
| | | IFNULL(COUNT(DISTINCT f.id), 0) AS personTotalNum, |
| | | IFNULL(COUNT(DISTINCT e.id), 0) AS personTotalNum, |
| | | t.exam_name |
| | | FROM t_exam_paper a |
| | | INNER JOIN t_exam t ON a.id = t.exam_paper_id AND t.deleted = 0 |
| | | LEFT JOIN t_subject b ON a.subject_id = b.id AND b.deleted = 0 |
| | | LEFT JOIN t_user c ON t.teacher_id = c.id AND c.deleted = 0 |
| | | LEFT JOIN t_exam_paper_score d ON t.id = d.exam_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 |
| | | LEFT JOIN t_exam_paper_score d ON t.id = d.exam_id AND d.deleted = 0 |
| | | LEFT JOIN t_classes_user e ON t.classes_id = e.classes_id AND e.deleted = 0 |
| | | <where> |
| | | a.deleted = 0 |
| | | <if test="subjectId != null and subjectId.size() > 0"> |
| | |
| | | <if test="examName != null and examName != ''"> |
| | | AND INSTR(t.exam_name, #{examName}) |
| | | </if> |
| | | <if test="examId != null and examId != ''"> |
| | | AND t.id = #{examId} |
| | | </if> |
| | | </where> |
| | | GROUP BY t.id |
| | | ORDER BY t.id DESC |
| | | </select> |
| | | |
| | | <select id="pageUser" resultType="com.ycl.jxkg.domain.vo.student.exampaper.UserAnswerPageResponseVO"> |
| | | SELECT a.id, a.real_name AS userName, COUNT(b.id) AS examCount |
| | | FROM t_user a |
| | | LEFT JOIN t_exam_paper_score b ON a.id = b.user_id AND b.deleted = 0 |
| | | <where> |
| | | a.deleted = 0 AND a.role = 1 |
| | | <if test="name != null and name != ''"> |
| | | AND INSTR(a.real_name, #{name}) |
| | | </if> |
| | | </where> |
| | | GROUP BY a.id |
| | | </select> |
| | | |
| | | <select id="selectByUserId" resultType="com.ycl.jxkg.domain.entity.ExamPaperScore"> |
| | | SELECT |
| | | <include refid="Base_Column_List"/> |
| | | from t_exam_paper_score |
| | | where user_id = #{userId} |
| | | </select> |
| | | <select id="checkWrong" resultType="com.ycl.jxkg.domain.entity.ExamPaperScore"> |
| | | SELECT |
| | | <include refid="Base_Column_List"/> |
| | | from t_exam_paper_score AS eps, |
| | | JSON_TABLE(paper_content, '$[*]' COLUMNS( |
| | | questionType INT PATH '$.questionType', |
| | | questionId INT PATH '$.questionList[*].questionId' |
| | | )) AS pc |
| | | <where> |
| | | eps.exam_id = #{examId} |
| | | AND eps.user_id = #{userId} |
| | | AND pc.questionType = #{questionType} |
| | | AND pc.questionId = #{questionId} |
| | | </where> |
| | | </select> |
| | | |
| | | <select id="getClassExamScoreInfo" resultType="com.ycl.jxkg.domain.vo.admin.exam.ClassExamScoreInfoVO"> |
| | | SELECT |
| | | u.id AS user_id, |
| | | u.real_name, |
| | | (select exam_name from t_exam e WHERE e.id = #{id}) AS exam_name, |
| | | COALESCE(eps.total_score,0.00) AS total_score, |
| | | COUNT(CASE WHEN eps.id IS NULL THEN 1 END) OVER () AS lackUserCount |
| | | FROM t_user u |
| | | LEFT JOIN t_classes_user cu ON cu.user_id = u.id |
| | | LEFT JOIN t_exam_paper_score eps ON eps.user_id = u.id and eps.exam_id = #{id} |
| | | WHERE |
| | | cu.deleted = 0 |
| | | and teacher = 0 |
| | | and cu.classes_id = (select classes_id from t_exam e WHERE e.id = #{id}) |
| | | </select> |
| | | </mapper> |