Browse Source

考试报告

tags/正式版本
雍文秀 2 years ago
parent
commit
c77a703b47

+ 3
- 2
sexam/src/main/java/com/xhkjedu/sexam/controller/paper/EPaperCorrectTeacherController.java View File

82
     public ResultVo getCorrectQuestion(@RequestBody EPTeacherVo vo) {
82
     public ResultVo getCorrectQuestion(@RequestBody EPTeacherVo vo) {
83
         Integer teacherid = vo.getTeacherid();
83
         Integer teacherid = vo.getTeacherid();
84
         String eptqids = vo.getEptqids();
84
         String eptqids = vo.getEptqids();
85
-        N_Utils.validation(new Object[]{teacherid, "教师id", 1, eptqids, "试卷试题ids", 2});
86
-        return correctTeacherService.getCorrectQuestion(teacherid, eptqids, vo.getClassids());
85
+        Integer esid = vo.getEsid();
86
+        N_Utils.validation(new Object[]{teacherid, "教师id", 1, eptqids, "试卷试题ids", 2, esid, "考试科目id", 1});
87
+        return correctTeacherService.getCorrectQuestion(teacherid, eptqids, vo.getClassids(), esid);
87
     }
88
     }
88
 
89
 
89
     /**
90
     /**

+ 3
- 0
sexam/src/main/java/com/xhkjedu/sexam/mapper/paper/EPaperCorrectTeacherMapper.java View File

38
 
38
 
39
     //修改学生试卷批阅状态
39
     //修改学生试卷批阅状态
40
     void updateCheckStuById(@Param("epsid") Integer epsid, @Param("checkid") Integer checkid);
40
     void updateCheckStuById(@Param("epsid") Integer epsid, @Param("checkid") Integer checkid);
41
+
42
+    //根据考试科目id获取考试名称
43
+    Map getExamNameByEsId(@Param("esid") Integer esid);
41
 }
44
 }

+ 7
- 4
sexam/src/main/java/com/xhkjedu/sexam/mapper/paperstudent/EPaperStudentMapper.java View File

3
 import com.xhkjedu.sexam.base.TkMapper;
3
 import com.xhkjedu.sexam.base.TkMapper;
4
 import com.xhkjedu.sexam.model.paper.EPaperQtype;
4
 import com.xhkjedu.sexam.model.paper.EPaperQtype;
5
 import com.xhkjedu.sexam.model.paperstudent.EPaperStudent;
5
 import com.xhkjedu.sexam.model.paperstudent.EPaperStudent;
6
+import com.xhkjedu.sexam.model.reportstu.ERstudent;
6
 import com.xhkjedu.sexam.vo.paperstudent.EPaperStudentVo;
7
 import com.xhkjedu.sexam.vo.paperstudent.EPaperStudentVo;
7
 import org.apache.ibatis.annotations.Param;
8
 import org.apache.ibatis.annotations.Param;
8
 import org.springframework.stereotype.Repository;
9
 import org.springframework.stereotype.Repository;
44
     List<EPaperQtype> listStuPaperFjQuestionsForWeb(@Param("epsid")Integer epsid);
45
     List<EPaperQtype> listStuPaperFjQuestionsForWeb(@Param("epsid")Integer epsid);
45
 
46
 
46
     //学生提交试卷
47
     //学生提交试卷
47
-    int updateStudentPaper(@Param("ps")EPaperStudent ps);
48
+    int updateStudentPaper(@Param("ps") EPaperStudent ps);
48
 
49
 
49
     //更新缺考字段
50
     //更新缺考字段
50
-    void updateStudentPaperState(@Param("ps")EPaperStudent ps);
51
+    void updateStudentPaperState(@Param("ps") EPaperStudent ps);
51
 
52
 
52
     //根据试卷id批量修改该试卷学生得分
53
     //根据试卷id批量修改该试卷学生得分
53
-    void updateBathStudentPaperScoreByEpid(@Param("epid")Integer epid);
54
+    void updateBathStudentPaperScoreByEpid(@Param("epid") Integer epid);
54
 
55
 
55
     //根据试卷id和学生id获取学生试卷信息
56
     //根据试卷id和学生id获取学生试卷信息
56
-    EPaperStudent getPaperStudentByStuidAndEpid(@Param("epid")Integer epid,@Param("studentid")Integer studentid);
57
+    EPaperStudent getPaperStudentByStuidAndEpid(@Param("epid") Integer epid, @Param("studentid") Integer studentid);
58
+
59
+    List<ERstudent> listByExamId(@Param("examid") Integer examid);
57
 }
60
 }

+ 5
- 0
sexam/src/main/java/com/xhkjedu/sexam/model/reportstu/ERstudent.java View File

5
 
5
 
6
 import javax.persistence.Id;
6
 import javax.persistence.Id;
7
 import javax.persistence.Table;
7
 import javax.persistence.Table;
8
+import javax.persistence.Transient;
8
 
9
 
9
 @Table(name = "e_rstudent")
10
 @Table(name = "e_rstudent")
10
 @Data
11
 @Data
57
 
58
 
58
     //下次目标
59
     //下次目标
59
     private Integer nextgoal;
60
     private Integer nextgoal;
61
+
62
+    @Transient
63
+    //状态0未进场1已进场2已交卷3缺考
64
+    private Integer sstate;
60
 }
65
 }

+ 3
- 4
sexam/src/main/java/com/xhkjedu/sexam/service/paper/EPaperCorrectTeacherService.java View File

12
 import org.springframework.stereotype.Service;
12
 import org.springframework.stereotype.Service;
13
 
13
 
14
 import javax.annotation.Resource;
14
 import javax.annotation.Resource;
15
-import java.util.HashMap;
16
 import java.util.List;
15
 import java.util.List;
17
 import java.util.Map;
16
 import java.util.Map;
18
 import java.util.concurrent.Future;
17
 import java.util.concurrent.Future;
38
     }
37
     }
39
 
38
 
40
     //随机获取待批试题
39
     //随机获取待批试题
41
-    public ResultVo getCorrectQuestion(Integer teacherid, String eptqids, String classids) {
40
+    public ResultVo getCorrectQuestion(Integer teacherid, String eptqids, String classids, Integer esid) {
42
         lock.lock();
41
         lock.lock();
43
-        Map map = new HashMap();
42
+        Map map = correctTeacherMapper.getExamNameByEsId(esid);//根据考试科目id获取考试名称
44
         try {
43
         try {
45
             //随机获取一条待批阅试题
44
             //随机获取一条待批阅试题
46
             EPaperSQuestionVo sq = correctTeacherMapper.getCorrectQuestion(teacherid, eptqids, classids);
45
             EPaperSQuestionVo sq = correctTeacherMapper.getCorrectQuestion(teacherid, eptqids, classids);
47
-            if (sq == null) return new ResultVo(1, "已批阅完成");
46
+            if (sq == null) return new ResultVo(0, "已批阅完成");
48
             //修改试卷学生试题为批阅中
47
             //修改试卷学生试题为批阅中
49
             correctTeacherMapper.updateCheckQuestionById(sq.getEpsqid(), teacherid);
48
             correctTeacherMapper.updateCheckQuestionById(sq.getEpsqid(), teacherid);
50
             //试题批阅情况
49
             //试题批阅情况

+ 160
- 0
sexam/src/main/java/com/xhkjedu/sexam/service/report/EReportGenerateService.java View File

1
+package com.xhkjedu.sexam.service.report;
2
+
3
+import com.xhkjedu.sexam.mapper.exam.EBaseMapper;
4
+import com.xhkjedu.sexam.mapper.exam.EClassMapper;
5
+import com.xhkjedu.sexam.mapper.exam.ESubjectMapper;
6
+import com.xhkjedu.sexam.mapper.paperstudent.EPaperStudentMapper;
7
+import com.xhkjedu.sexam.mapper.report.ERbaseMapper;
8
+import com.xhkjedu.sexam.mapper.reportstu.ERstudentMapper;
9
+import com.xhkjedu.sexam.model.reportstu.ERstudent;
10
+import org.springframework.stereotype.Service;
11
+
12
+import javax.annotation.Resource;
13
+import java.util.ArrayList;
14
+import java.util.DoubleSummaryStatistics;
15
+import java.util.HashMap;
16
+import java.util.List;
17
+import java.util.Map;
18
+import java.util.stream.Collectors;
19
+
20
+/**
21
+ * @author ywx
22
+ * @classname EReportGenerateService
23
+ * @description 考试报告生成
24
+ * @date 2022/8/8 10:04
25
+ **/
26
+@Service
27
+public class EReportGenerateService {
28
+    @Resource
29
+    private EBaseMapper eBaseMapper;
30
+    @Resource
31
+    private EClassMapper eClassMapper;
32
+    @Resource
33
+    private ESubjectMapper eSubjectMapper;
34
+    @Resource
35
+    private EPaperStudentMapper ePaperStudentMapper;
36
+
37
+    @Resource
38
+    private ERbaseMapper eRbaseMapper;
39
+    @Resource
40
+    private ERstudentMapper eRstudentMapper;
41
+
42
+    //生成考试报告
43
+    public void generateExamReport(Integer examid) {
44
+        List<Map> classes = eClassMapper.listByExamId(examid);
45
+        List<Map> subjects = eSubjectMapper.listSubject(examid);
46
+        int classnum = classes.size();
47
+        int stunum = classes.stream().mapToInt(m -> (int) m.get("classnum")).sum();
48
+        int subjectnum = subjects.size();
49
+        /*ERbase rbase = new ERbase();
50
+        rbase.setExamid(examid);
51
+        rbase.setClassnum(classnum);
52
+        rbase.setStunum(stunum);
53
+        rbase.setSubjectnum(subjectnum);
54
+        eRbaseMapper.insertSelective(rbase);*/
55
+
56
+        String subjectid = "zf";
57
+        String subjectname = "总分";
58
+        Map<String, String> subjectMap = subjects.stream().collect(Collectors.toMap(m -> m.get("subjectid").toString(),
59
+                m -> m.get("subjectname").toString()));
60
+
61
+        List<ERstudent> schoolStudents = new ArrayList<>();//学校学生成绩
62
+        List<ERstudent> classStudents = new ArrayList<>();//班级学生成绩
63
+        List<ERstudent> subjectStudents = new ArrayList<>();//科目学生成绩、
64
+        Map<String, Integer> schoolRank = new HashMap<>();//学校分数排名
65
+        Map<String, Integer> classRank = new HashMap<>();//班级分数排名
66
+        Map<String, Integer> ssubjectRank = new HashMap<>();//学校科目分数排名
67
+        Map<String, Integer> csubjectRank = new HashMap<>();//班级科目分数排名
68
+
69
+        List<ERstudent> students = ePaperStudentMapper.listByExamId(examid);
70
+        Map<Integer, List<ERstudent>> schoolCollect = students.stream().collect(Collectors.groupingBy(s -> s.getStudentid()));
71
+        for (Map.Entry<Integer, List<ERstudent>> entry : schoolCollect.entrySet()) {
72
+            Integer studentid = entry.getKey();
73
+            ERstudent cs = new ERstudent();
74
+            cs.setStudentid(studentid);
75
+            cs.setScore(entry.getValue().stream().mapToDouble(s -> s.getScore()).sum());
76
+            schoolStudents.add(cs);
77
+        }
78
+        setRank(schoolStudents, schoolRank, 1);//学校分数排名
79
+
80
+        Map<Integer, List<ERstudent>> cCollect = students.stream().collect(Collectors.groupingBy(s -> s.getClassid()));
81
+        for (Map.Entry<Integer, List<ERstudent>> entry : cCollect.entrySet()) {
82
+            Integer classid = entry.getKey();
83
+            List<ERstudent> studentList = entry.getValue();
84
+            Map<Integer, List<ERstudent>> sCollect = studentList.stream().collect(Collectors.groupingBy(s -> s.getStudentid()));
85
+            for (Map.Entry<Integer, List<ERstudent>> csEntry : sCollect.entrySet()) {
86
+                ERstudent cs = new ERstudent();
87
+                cs.setClassid(classid);
88
+                cs.setStudentid(csEntry.getKey());
89
+                cs.setSubjectid(subjectid);
90
+                cs.setSubjectname(subjectname);
91
+                cs.setScore(csEntry.getValue().stream().mapToDouble(s -> s.getScore()).sum());
92
+                classStudents.add(cs);
93
+            }
94
+            setRank(classStudents, classRank, 2);//班级分数排名
95
+
96
+            Map<String, List<ERstudent>> subCollect = studentList.stream().collect(Collectors.groupingBy(s -> s.getSubjectid()));
97
+            for (Map.Entry<String, List<ERstudent>> ssEntry : subCollect.entrySet()) {
98
+                subjectid = ssEntry.getKey();
99
+                subjectname = subjectMap.get(subjectid);
100
+                studentList = ssEntry.getValue();
101
+                for (ERstudent cs : studentList) {
102
+                    cs.setSubjectname(subjectname);
103
+                    subjectStudents.add(cs);
104
+                }
105
+            }
106
+            setRank(subjectStudents, ssubjectRank, 3);//科目分数排名
107
+        }
108
+
109
+        DoubleSummaryStatistics schoolStatistics = schoolStudents.stream().mapToDouble(s -> s.getScore()).summaryStatistics();
110
+        DoubleSummaryStatistics classStatistics = classStudents.stream().mapToDouble(s -> s.getScore()).summaryStatistics();
111
+        for (ERstudent cs : classStudents) {
112
+            Integer studentid = cs.getStudentid();
113
+            cs.setClassrank(classRank.get(cs.getClassid()+"_"+ studentid));
114
+            cs.setClassmaxscore(classStatistics.getMax());
115
+            cs.setClassavgscore(classStatistics.getAverage());
116
+            cs.setSchoolrank(schoolRank.get(studentid));
117
+            cs.setSchoolmaxscore(schoolStatistics.getMax());
118
+            cs.setSchoolavgscore(schoolStatistics.getAverage());
119
+        }
120
+        eRstudentMapper.insertList(classStudents);
121
+
122
+        for (ERstudent cs : subjectStudents) {
123
+            Integer studentid = cs.getStudentid();
124
+            cs.setClassrank(classRank.get(cs.getClassid()+"_"+ studentid));
125
+            cs.setClassmaxscore(classStatistics.getMax());
126
+            cs.setClassavgscore(classStatistics.getAverage());
127
+            cs.setSchoolrank(schoolRank.get(studentid));
128
+            cs.setSchoolmaxscore(schoolStatistics.getMax());
129
+            cs.setSchoolavgscore(schoolStatistics.getAverage());
130
+        }
131
+        eRstudentMapper.insertList(subjectStudents);
132
+    }
133
+
134
+    //分数排名
135
+    private void setRank(List<ERstudent> students, Map<String, Integer> rank, Integer code) {
136
+        students =
137
+                students.stream().sorted((s1, s2) -> -Double.compare(s1.getScore(), s2.getScore())).collect(Collectors.toList());
138
+        List<Map.Entry<Double, List<ERstudent>>> gslist2 = students.stream()
139
+                .collect(Collectors.groupingBy(ERstudent::getScore)).entrySet()
140
+                .stream().sorted((s1, s2) -> -Double.compare(s1.getKey(), s2.getKey())).collect(Collectors.toList());
141
+        Integer index = 1;
142
+        String key;
143
+        for (Map.Entry<Double, List<ERstudent>> entry : gslist2) {
144
+            for (ERstudent cgs : entry.getValue()) {
145
+                Integer studentid = cgs.getStudentid();
146
+                Integer classid = cgs.getClassid();
147
+                String subjectid = cgs.getSubjectid();
148
+                if (code == 1) {//学校
149
+                    key = studentid.toString();
150
+                } else if (code == 2) {//班级
151
+                    key = classid + "_" + studentid;
152
+                } else {//科目
153
+                    key = subjectid + "_" + studentid;
154
+                }
155
+                rank.put(key, index);
156
+            }
157
+            index = index + entry.getValue().size();
158
+        }
159
+    }
160
+}

+ 3
- 0
sexam/src/main/java/com/xhkjedu/sexam/vo/paper/EPTeacherVo.java View File

10
  **/
10
  **/
11
 @Data
11
 @Data
12
 public class EPTeacherVo {
12
 public class EPTeacherVo {
13
+    //考试科目id
14
+    private Integer esid;
15
+
13
     //试卷id
16
     //试卷id
14
     private Integer epid;
17
     private Integer epid;
15
 
18
 

+ 5
- 0
sexam/src/main/resources/mapper/paper/EPaperCorrectTeacherMapper.xml View File

101
         ,ps.stuscore=(select sum(psq.stuscore) from e_paper_student_question psq where psq.epsid=ps.epsid)
101
         ,ps.stuscore=(select sum(psq.stuscore) from e_paper_student_question psq where psq.epsid=ps.epsid)
102
         where ps.epsid=#{epsid}
102
         where ps.epsid=#{epsid}
103
     </update>
103
     </update>
104
+    <!--根据考试科目id获取考试名称-->
105
+    <select id="getExamNameByEsId" resultType="java.util.Map">
106
+        select es.subjectname,eb.examname
107
+        from e_subject es left join e_base eb on eb.examid = es.examid where es.esid=#{esid}
108
+    </select>
104
 </mapper>
109
 </mapper>

+ 5
- 0
sexam/src/main/resources/mapper/paperstudent/EPaperStudentMapper.xml View File

187
     <select id="getPaperStudentByStuidAndEpid" resultType="com.xhkjedu.sexam.model.paperstudent.EPaperStudent">
187
     <select id="getPaperStudentByStuidAndEpid" resultType="com.xhkjedu.sexam.model.paperstudent.EPaperStudent">
188
         select * from e_paper_student where epid=#{epid} and studentid=#{studentid} order by epsid desc limit 1
188
         select * from e_paper_student where epid=#{epid} and studentid=#{studentid} order by epsid desc limit 1
189
     </select>
189
     </select>
190
+
191
+    <select id="listByExamId" resultType="com.xhkjedu.sexam.model.reportstu.ERstudent">
192
+        select classid,examid,subjectid,studentid,stuscore score,sstate
193
+        from e_paper_student where examid=#{examid}
194
+    </select>
190
 </mapper>
195
 </mapper>

Loading…
Cancel
Save