From 247cb86585a1d1894596ed18a6c93efecb992946 Mon Sep 17 00:00:00 2001 From: luohairen <3399054449@qq.com> Date: 星期四, 14 十一月 2024 10:34:27 +0800 Subject: [PATCH] 班级成绩图表分析 --- src/main/resources/mapper/ExamPaperScoreMapper.xml | 33 +++++++++++++++++++++++++++++++-- 1 files changed, 31 insertions(+), 2 deletions(-) diff --git a/src/main/resources/mapper/ExamPaperScoreMapper.xml b/src/main/resources/mapper/ExamPaperScoreMapper.xml index 0c5d29f..3c6aff2 100644 --- a/src/main/resources/mapper/ExamPaperScoreMapper.xml +++ b/src/main/resources/mapper/ExamPaperScoreMapper.xml @@ -21,6 +21,7 @@ <result column="paper_content" property="paperContent"/> <result column="navbar" property="navbar"/> </resultMap> + <sql id="Base_Column_List"> id, exam_id, @@ -176,7 +177,35 @@ from t_exam_paper_score where user_id = #{userId} </select> - <select id="selectWrong" resultType="com.ycl.jxkg.domain.vo.student.wrong.WrongResponseVO"> - + <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> -- Gitblit v1.8.0