From c227e3938798eb7d529575ba1f3ea1c56ae63cfe Mon Sep 17 00:00:00 2001
From: 龚焕茏 <2842157468@qq.com>
Date: 星期一, 01 七月 2024 13:16:34 +0800
Subject: [PATCH] refactor:恢复成绩接口

---
 src/main/resources/mapper/ExamPaperScoreMapper.xml |   75 +++++++++++++++++++------------------
 1 files changed, 39 insertions(+), 36 deletions(-)

diff --git a/src/main/resources/mapper/ExamPaperScoreMapper.xml b/src/main/resources/mapper/ExamPaperScoreMapper.xml
index 0c4926f..aa4d216 100644
--- a/src/main/resources/mapper/ExamPaperScoreMapper.xml
+++ b/src/main/resources/mapper/ExamPaperScoreMapper.xml
@@ -22,50 +22,55 @@
         <result column="navbar" property="navbar"/>
     </resultMap>
     <sql id="Base_Column_List">
-        id
-        , paper_id, paper_name, paper_type, score,total_score,
-        question_correct, question_count, do_time, status, user_id, exam_id,exam_name,
-        judge_user,submit_time,paper_content,judge_time,navbar
+        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
+        FROM t_exam_paper_score
         <where>
             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_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 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 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>
 
 
@@ -80,14 +85,12 @@
 
     <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.*, 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 paper_id = #{examPaperId}
-            </if>
+            exam_id = #{examId}
             <if test="userName != null and userName != ''">
                 AND INSTR(b.real_name, #{userName})
             </if>
@@ -96,9 +99,9 @@
 
     <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,
@@ -110,9 +113,9 @@
         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_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
         <where>

--
Gitblit v1.8.0