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 |  185 ++++++++++++++++++++++++++++++++++------------
 1 files changed, 137 insertions(+), 48 deletions(-)

diff --git a/src/main/resources/mapper/ExamPaperScoreMapper.xml b/src/main/resources/mapper/ExamPaperScoreMapper.xml
index e96bfef..3c6aff2 100644
--- a/src/main/resources/mapper/ExamPaperScoreMapper.xml
+++ b/src/main/resources/mapper/ExamPaperScoreMapper.xml
@@ -2,90 +2,127 @@
 <!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_paper_id" jdbcType="INTEGER" property="examPaperId"/>
-        <result column="paper_name" jdbcType="VARCHAR" property="paperName"/>
-        <result column="paper_type" jdbcType="INTEGER" property="paperType"/>
-        <result column="subject_id" jdbcType="INTEGER" property="subjectId"/>
-        <result column="system_score" jdbcType="INTEGER" property="systemScore"/>
-        <result column="user_score" jdbcType="INTEGER" property="userScore"/>
-        <result column="paper_score" jdbcType="INTEGER" property="paperScore"/>
-        <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="create_user" jdbcType="INTEGER" property="createUser"/>
-        <result column="create_time" jdbcType="TIMESTAMP" property="createTime"/>
-        <result column="task_exam_id" jdbcType="INTEGER" property="taskExamId"/>
+        <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_paper_id, paper_name, paper_type, subject_id, system_score, user_score,
-    paper_score, question_correct, question_count, do_time, status, create_user, create_time,
-    task_exam_id
+        id,
+        exam_id,
+        exam_name,
+        paper_id,
+        paper_type,
+        score,
+        total_score,
+        question_correct,
+        question_count,
+        do_time,
+        status,
+        user_id,
+        judge_user,
+        submit_time,
+        paper_content,
+        navbar,
+        judge_time,
+        deleted
     </sql>
 
-    <select id="studentPage" resultMap="BaseResultMap"
-            parameterType="com.ycl.jxkg.domain.vo.student.exampaper.ExamPaperAnswerPageVO">
+    <select id="studentPage" resultType="com.ycl.jxkg.domain.vo.student.exampaper.ExamPaperAnswerPageResponseVO">
         SELECT
-        <include refid="Base_Column_List"/>
-        FROM t_exam_paper_answer
+        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 create_user = #{createUser}
-            <if test="subjectId != null">
-                and subject_id = #{subjectId}
+            AND user_id = #{createUser}
+            <if test="examName != null and 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_answer
+        from t_exam_paper_score
     </select>
 
+    <select id="selectAllQuestionCount" resultType="java.lang.Integer">
+        SELECT sum(question_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
+        SELECT submit_time as name, sum(question_count) as value
         from
             (
-            SELECT DATE_FORMAT(create_time, '%Y-%m-%d') as create_time from t_exam_paper_answer
-            WHERE create_time between #{startTime} and #{endTime}
+            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 create_time
+        GROUP BY submit_time
     </select>
 
 
     <select id="getByPidUid" resultMap="BaseResultMap">
         select
         <include refid="Base_Column_List"/>
-        from t_exam_paper_answer
-        where exam_paper_id = #{pid} and create_user=#{uid}
+        from t_exam_paper_score
+        where paper_id = #{pid} and user_id=#{uid}
         limit 1
     </select>
 
 
     <select id="adminPage" resultType="com.ycl.jxkg.domain.vo.student.exampaper.ExamPaperAnswerPageResponseVO">
         SELECT
-        a.id , exam_paper_id, paper_name, paper_type, system_score, user_score, paper_score,
-        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
+        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>
-            <if test="examPaperId != null">
-                AND exam_paper_id = #{examPaperId}
+            <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>
 
     <select id="pageExamPaper" resultType="com.ycl.jxkg.domain.vo.student.exampaper.ExamPaperAnswerPageResponseVO">
         SELECT
-        a.id,
+        t.id,
         a.name AS paperName,
-        a.score AS systemScore,
+        a.score AS totalScore,
         a.num as questionCount,
         a.subject_id,
         a.paper_type,
@@ -93,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
-        LEFT JOIN t_user c ON t.teacher_id = 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
+        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 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">
@@ -114,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>

--
Gitblit v1.8.0