luohairen
2024-11-14 247cb86585a1d1894596ed18a6c93efecb992946
src/main/resources/mapper/ExamPaperScoreMapper.xml
@@ -2,24 +2,26 @@
<!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,
@@ -43,17 +45,27 @@
    <select id="studentPage" resultType="com.ycl.jxkg.domain.vo.student.exampaper.ExamPaperAnswerPageResponseVO">
        SELECT
        <include refid="Base_Column_List"/>
        FROM t_exam_paper_score
        a.*,
        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
@@ -65,11 +77,13 @@
    </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>
@@ -84,14 +98,22 @@
    <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>
@@ -108,15 +130,14 @@
        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">
@@ -129,9 +150,62 @@
            <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>