龚焕茏
2024-06-06 2354b39c08f9cbe6c2878ee768abd9748c3c21b5
src/main/resources/mapper/ExamPaperAnswerMapper.xml
@@ -65,16 +65,51 @@
    </select>
    <select id="adminPage" resultMap="BaseResultMap"
            parameterType="com.ycl.jxkg.domain.vo.admin.paper.ExamPaperAnswerPageRequestVO">
    <select id="adminPage" resultMap="BaseResultMap" parameterType="com.ycl.jxkg.domain.vo.admin.paper.ExamPaperAnswerPageRequestVO">
        SELECT
        <include refid="Base_Column_List"/>
        FROM t_exam_paper_answer
        <where>
            <if test="subjectId != null">
                and subject_id = #{subjectId}
            <if test="subjectId != null and subjectId.size() > 0">
                AND subject_id IN
                <foreach collection="subjectId" item="item" open="(" separator="," close=")">#{item}</foreach>
            </if>
            <if test="examPaperId != null">
                AND exam_paper_id = #{examPaperId}
            </if>
        </where>
    </select>
    <select id="pageExamPaper" resultType="com.ycl.jxkg.domain.vo.student.exampaper.ExamPaperAnswerPageResponseVO">
        SELECT
        a.id,
        a.name AS paperName,
        a.score AS systemScore,
        a.question_count,
        a.subject_id,
        a.paper_type,
        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>