Browse Source

统计报表=>考点考场人员信息

zhuhaiwen 3 years ago
parent
commit
b1a430a908

+ 3 - 0
oa-app/src/main/java/com/css/oa/exam/assign/repository/Assign.java

60
    public String level_name;
60
    public String level_name;
61
61
62
    @Transient
62
    @Transient
63
    public String subject_name;
64
65
    @Transient
63
    public int is_assign;
66
    public int is_assign;
64
67
65
    @Transient
68
    @Transient

+ 5 - 0
oa-app/src/main/java/com/css/oa/exam/assign/repository/IAssignRepository.java

49
    @Query("select ass from Assign ass where ass.adm_num is not null and ass.student_id = :student_id")
49
    @Query("select ass from Assign ass where ass.adm_num is not null and ass.student_id = :student_id")
50
    List<Assign> myAdm(String student_id);
50
    List<Assign> myAdm(String student_id);
51
51
52
    @Modifying
53
    @Transactional
54
    @Query("select ass from Assign ass where ass.exam_id = :exam_id and ass.place_id = :place_id")
55
    List<Assign> findAllByPlace_id(@Param("exam_id") String exam_id, @Param("place_id") String place_id);
56
52
}
57
}

+ 8 - 2
oa-app/src/main/java/com/css/oa/exam/assign/service/BaseAssignService.java

7
import com.css.oa.exam.base.BaseVerifyService;
7
import com.css.oa.exam.base.BaseVerifyService;
8
import com.css.oa.exam.constants.BoolState;
8
import com.css.oa.exam.constants.BoolState;
9
import com.css.oa.exam.constants.VerifyState;
9
import com.css.oa.exam.constants.VerifyState;
10
import com.css.oa.exam.exam.repository.Exam;
11
import com.css.oa.exam.exam.repository.IExamRepository;
10
import com.css.oa.exam.place.repository.IPlaceRepository;
12
import com.css.oa.exam.place.repository.IPlaceRepository;
11
import com.css.oa.exam.place.repository.Place;
13
import com.css.oa.exam.place.repository.Place;
12
import com.css.oa.exam.student.repository.IStudentRepository;
14
import com.css.oa.exam.student.repository.IStudentRepository;
90
        return null;
92
        return null;
91
    }
93
    }
92
94
95
    @Autowired
96
    IExamRepository examRepository;
97
93
    protected void setProperties(List<Assign> assignList) {
98
    protected void setProperties(List<Assign> assignList) {
94
        //设置审核状态
99
        //设置审核状态
95
        setVerifyState(assignList);
100
        setVerifyState(assignList);
108
            Place place = placeRepository.findById(assign.getWant_place_id()).get();
113
            Place place = placeRepository.findById(assign.getWant_place_id()).get();
109
            assign.setWant_place_name(place.getPlace_name());
114
            assign.setWant_place_name(place.getPlace_name());
110
115
111
            assign.setSeries_name("水利工程");
112
            assign.setLevel_name("中高级");
116
            Exam exam = examRepository.findById(assign.exam_id).get();
117
            assign.setSeries_name(exam.getSeries_name());
118
            assign.setLevel_name(exam.getLevel_name());
113
            boolean empty = TextUtils.isEmpty(assign.getRoom_id());
119
            boolean empty = TextUtils.isEmpty(assign.getRoom_id());
114
            assign.setIs_assign(empty ? BoolState.NO : BoolState.YES);
120
            assign.setIs_assign(empty ? BoolState.NO : BoolState.YES);
115
        }
121
        }

+ 5 - 0
oa-app/src/main/java/com/css/oa/exam/place/repository/IPlaceRepository.java

30
    @Query("select p from Place p where p.create_unit_id in :unitIds and p.exam_id = :exam_id and p.curr_unit_id = " + Unit.TOP_CODE)
30
    @Query("select p from Place p where p.create_unit_id in :unitIds and p.exam_id = :exam_id and p.curr_unit_id = " + Unit.TOP_CODE)
31
    List<Place> findAllByUnitIds(List<String> unitIds, String exam_id);
31
    List<Place> findAllByUnitIds(List<String> unitIds, String exam_id);
32
32
33
    @Modifying
34
    @Transactional
35
    @Query("select p from Place p where p.exam_id  = :exam_id")
36
    List<Place> findAllByExam_id(String exam_id);
37
33
}
38
}

+ 42 - 0
oa-app/src/main/java/com/css/oa/exam/report/bean/PRPExcelEntity.java

1
package com.css.oa.exam.report.bean;
2
3
import cn.afterturn.easypoi.excel.annotation.Excel;
4
import cn.afterturn.easypoi.excel.annotation.ExcelTarget;
5
6
@ExcelTarget("deptUtil")
7
public class PRPExcelEntity {
8
9
    @Excel(name = "考场", width = 30, needMerge = true)
10
    private String room_name;
11
12
    @Excel(name = "姓名", width = 30, needMerge = true)
13
    private String name;
14
15
    @Excel(name = "身份证", width = 30, needMerge = true)
16
    private String card_num;
17
18
    @Excel(name = "准考证", width = 30, needMerge = true)
19
    private String adm_num;
20
21
    @Excel(name = "座位号", width = 30, needMerge = true)
22
    private String seat_num;
23
24
    @Excel(name = "报考系列", width = 30, needMerge = true)
25
    private String series_name;
26
27
    @Excel(name = "报考级别", width = 30, needMerge = true)
28
    private String level_name;
29
30
    @Excel(name = "报考科目", width = 30, needMerge = true)
31
    private String subject_name;
32
33
    @Excel(name = "照片", width = 30, needMerge = true)
34
    private String pic;
35
36
    @Excel(name = "签名", width = 30, needMerge = true)
37
    private String autograph;
38
39
//    @ExcelCollection(name = "员工信息")
40
//    private List<EmpUtil> emps;
41
42
}

+ 19 - 0
oa-app/src/main/java/com/css/oa/exam/report/bean/PRPExportReq.java

1
package com.css.oa.exam.report.bean;
2
3
import com.css.oa.exam.constants.ExportDTO;
4
5
import java.util.ArrayList;
6
import java.util.List;
7
8
public class PRPExportReq {
9
10
    public String exam_id;
11
12
    public int curPage;
13
14
    public int pageSize;
15
16
    //key value
17
    public List<ExportDTO> dtos = new ArrayList<>();
18
19
}

+ 16 - 0
oa-app/src/main/java/com/css/oa/exam/report/bean/PRPReq.java

1
package com.css.oa.exam.report.bean;
2
3
import com.css.oa.exam.constants.ExportDTO;
4
5
import java.util.ArrayList;
6
import java.util.List;
7
8
public class PRPReq {
9
10
    public String place_id;
11
12
    public int curPage;
13
14
    public int pageSize;
15
16
}

+ 27 - 9
oa-app/src/main/java/com/css/oa/exam/report/controller/ReportController.java

1
package com.css.oa.exam.report.controller;
1
package com.css.oa.exam.report.controller;
2
2
3
import com.css.oa.exam.assign.bean.AssignExportReq;
3
import com.css.oa.exam.base.BaseController;
4
import com.css.oa.exam.base.BaseController;
5
import com.css.oa.exam.report.bean.PRPExportReq;
6
import com.css.oa.exam.report.bean.PRPReq;
4
import com.css.oa.exam.report.service.ReportService;
7
import com.css.oa.exam.report.service.ReportService;
5
import com.css.oa.utils.Result;
8
import com.css.oa.utils.Result;
6
import io.swagger.annotations.Api;
9
import io.swagger.annotations.Api;
9
import org.springframework.beans.factory.annotation.Autowired;
12
import org.springframework.beans.factory.annotation.Autowired;
10
import org.springframework.web.bind.annotation.*;
13
import org.springframework.web.bind.annotation.*;
11
14
15
import javax.servlet.http.HttpServletResponse;
12
import java.util.HashMap;
16
import java.util.HashMap;
13
import java.util.List;
17
import java.util.List;
14
import java.util.Map;
18
import java.util.Map;
36
    }
40
    }
37
41
38
    @ApiOperation(value = "统计报表-考点考场人员信息")
42
    @ApiOperation(value = "统计报表-考点考场人员信息")
39
    @GetMapping("/roomPeople")
40
    public Result roomPeople() {
43
    @PostMapping("/prp")
44
    public Result prp(@RequestBody PRPReq req) {
41
        Result<Map> result = null;
45
        Result<Map> result = null;
42
        try {
46
        try {
43
//            Map obj = mService.roomPeople();
44
//            result = setResult("res", obj);
47
            Map obj = mService.prp(req);
48
            result = setResult("res", obj);
45
        } catch (Exception e) {
49
        } catch (Exception e) {
46
            result = setErr(e.toString());
50
            result = setErr(e.toString());
47
            e.printStackTrace();
51
            e.printStackTrace();
49
        return result;
53
        return result;
50
    }
54
    }
51
55
56
    @ApiOperation(value = "统计报表-考点考场人员信息-导出")
57
    @PostMapping("/prp_export")
58
    public void prp_export(HttpServletResponse response, @RequestBody PRPExportReq req) {
59
        try {
60
            if (TextUtils.isEmpty(req.exam_id)) {
61
                exportPrint(response, "exam_id不能为空");
62
            }
63
            mService.prp_export(response, req);
64
        } catch (Exception e) {
65
            System.out.println(e.getMessage());
66
            exportPrint(response, e.getMessage());
67
        }
68
    }
69
52
    @ApiOperation(value = "统计报表-单位人员信息表")
70
    @ApiOperation(value = "统计报表-单位人员信息表")
53
    @GetMapping("/unitPeople")
54
    public Result unitPeople() {
71
    @GetMapping("/unit_personnel")
72
    public Result unit_personnel() {
55
        Result<Map> result = null;
73
        Result<Map> result = null;
56
        try {
74
        try {
57
//            Map obj = mService.unitPeople();
75
//            Map obj = mService.unitPeople();
64
    }
82
    }
65
83
66
    @ApiOperation(value = "统计报表-考点考场统计一览表")
84
    @ApiOperation(value = "统计报表-考点考场统计一览表")
67
    @GetMapping("/place_room")
68
    public Result place_room() {
85
    @GetMapping("/place_room_multi")
86
    public Result place_room_multi() {
69
        Result<Map> result = null;
87
        Result<Map> result = null;
70
        try {
88
        try {
71
//            Map obj = mService.place_room();
89
//            Map obj = mService.place_room();
77
        return result;
95
        return result;
78
    }
96
    }
79
97
80
    @ApiOperation(value = "统计报表-考点考场统计一览表")
98
    @ApiOperation(value = "统计报表-督考员一览表")
81
    @GetMapping("/monitor")
99
    @GetMapping("/monitor")
82
    public Result monitor() {
100
    public Result monitor() {
83
        Result<Map> result = null;
101
        Result<Map> result = null;

+ 136 - 6
oa-app/src/main/java/com/css/oa/exam/report/service/ReportService.java

1
package com.css.oa.exam.report.service;
1
package com.css.oa.exam.report.service;
2
2
3
import cn.afterturn.easypoi.excel.ExcelExportUtil;
4
import cn.afterturn.easypoi.excel.entity.ExportParams;
5
import cn.afterturn.easypoi.excel.entity.enmus.ExcelType;
6
import cn.afterturn.easypoi.excel.entity.params.ExcelExportEntity;
7
import com.css.oa.exam.admin.bean.Admin;
8
import com.css.oa.exam.assign.bean.AssignExportReq;
9
import com.css.oa.exam.assign.repository.Assign;
10
import com.css.oa.exam.assign.repository.AssignRecord;
11
import com.css.oa.exam.assign.repository.IAssignRepository;
3
import com.css.oa.exam.base.BaseService;
12
import com.css.oa.exam.base.BaseService;
13
import com.css.oa.exam.constants.BoolState;
14
import com.css.oa.exam.constants.ExamConfig;
15
import com.css.oa.exam.constants.ExportDTO;
16
import com.css.oa.exam.exam.repository.Exam;
17
import com.css.oa.exam.exam.repository.IExamRepository;
18
import com.css.oa.exam.place.repository.IPlaceRepository;
19
import com.css.oa.exam.place.repository.Place;
20
import com.css.oa.exam.report.bean.PRPExcelEntity;
21
import com.css.oa.exam.report.bean.PRPExportReq;
22
import com.css.oa.exam.report.bean.PRPReq;
23
import com.css.oa.exam.room.repository.IRoomRepository;
24
import com.css.oa.exam.score.bean.AnalyseColumn;
25
import com.css.oa.exam.student.repository.IStudentRepository;
26
import com.css.oa.exam.student.repository.Student;
27
import com.css.oa.exam.util.CopyObjTool;
28
import com.css.oa.exam.util.ExcelDelegate;
29
import com.css.oa.exam.util.ExportHelper;
4
import lombok.extern.slf4j.Slf4j;
30
import lombok.extern.slf4j.Slf4j;
31
import org.apache.http.util.TextUtils;
32
import org.apache.poi.hssf.usermodel.HSSFRow;
33
import org.apache.poi.hssf.usermodel.HSSFSheet;
34
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
35
import org.apache.poi.ss.usermodel.Workbook;
36
import org.springframework.beans.BeanUtils;
37
import org.springframework.beans.factory.annotation.Autowired;
38
import org.springframework.data.domain.Page;
39
import org.springframework.data.domain.PageRequest;
40
import org.springframework.data.jpa.domain.Specification;
5
import org.springframework.stereotype.Service;
41
import org.springframework.stereotype.Service;
6
42
43
import javax.persistence.criteria.*;
44
import javax.servlet.http.HttpServletResponse;
45
import java.io.BufferedOutputStream;
46
import java.io.ByteArrayInputStream;
47
import java.io.ByteArrayOutputStream;
48
import java.io.OutputStream;
49
import java.net.URLEncoder;
7
import java.util.ArrayList;
50
import java.util.ArrayList;
8
import java.util.HashMap;
51
import java.util.HashMap;
9
import java.util.List;
52
import java.util.List;
21
        map.put("list", arr);
64
        map.put("list", arr);
22
        return map;
65
        return map;
23
    }
66
    }
24
//
25
//    @Autowired
26
//    IExamRepository repository;
27
//
28
//    @Autowired
29
//    IUnitRepository unitRepository;
67
68
    @Autowired
69
    IRoomRepository roomRepository;
70
    @Autowired
71
    IAssignRepository assignRepository;
72
    @Autowired
73
    IStudentRepository studentRepository;
74
    @Autowired
75
    IExamRepository examRepository;
76
77
    public Map prp(PRPReq req) {
78
        if (req.pageSize == 0) {
79
            req.pageSize = 20;
80
        }
81
        List<String> roomIds = roomRepository.findAllIdByPlace_id(req.place_id);
82
        Specification<Assign> spec = new Specification<Assign>() {
83
            @Override
84
            public Predicate toPredicate(Root<Assign> root, CriteriaQuery<?> criteriaQuery, CriteriaBuilder criteriaBuilder) {
85
                List<Predicate> predicateList = new ArrayList<>();
86
                //0.所属考试
87
                if (roomIds.size() > 0) {
88
                    Path<String> path = root.get("room_id");//定义查询的字段
89
                    CriteriaBuilder.In<String> in = criteriaBuilder.in(path);
90
                    for (int i = 0; i < roomIds.size(); i++) {
91
                        in.value(roomIds.get(i));//存入值
92
                    }
93
                    predicateList.add(in);
94
                }
95
                Predicate[] pre = new Predicate[predicateList.size()];
96
                pre = predicateList.toArray(pre);
97
                return criteriaQuery.where(pre).getRestriction();
98
            }
99
        };
100
        PageRequest pageReques = PageRequest.of(req.curPage, req.pageSize);
101
        Page<Assign> pages = assignRepository.findAll(spec, pageReques);
102
        List<Assign> list = pages.getContent();
103
104
        setAssignProperties(list);
105
        Map map = new HashMap();
106
        map.put("total", list.size());
107
        map.put("list", list);
108
        return map;
109
    }
110
111
    private void setAssignProperties(List<Assign> list) {
112
        for (Assign assign : list) {
113
            //附加学生信息
114
            String student_id = assign.getStudent_id();
115
            Student student = studentRepository.findById(student_id).get();
116
            CopyObjTool.copyProperties(student, assign);
117
            Exam exam = examRepository.findById(assign.exam_id).get();
118
            assign.setSeries_name(exam.getSeries_name());
119
            assign.setLevel_name(exam.getLevel_name());
120
            assign.setSubject_name(exam.getSubject_name());
121
        }
122
    }
123
124
    @Autowired
125
    IPlaceRepository placeRepository;
126
127
    public void prp_export(HttpServletResponse response, PRPExportReq req) {
128
        //查询所有考点
129
        List<Place> places = placeRepository.findAllByExam_id(req.exam_id);
130
131
        List<Map<String, Object>> sheetsList = new ArrayList<>();
132
        for (int i = 0; i < places.size(); i++) {
133
            Place place = places.get(i);
134
            List<Assign> list = assignRepository.findAllByPlace_id(req.exam_id, place.getUuid());
135
            setAssignProperties(list);
136
            List<PRPExcelEntity> beans = new ArrayList<>();
137
            for (Assign assign : list) {
138
                PRPExcelEntity entity = new PRPExcelEntity();
139
                BeanUtils.copyProperties(assign, entity);
140
                beans.add(entity);
141
            }
142
            ExportParams exportParams = new ExportParams();
143
            exportParams.setSheetName(place.getPlace_name());
144
            // 创建sheet1使用得map
145
            Map<String, Object> map = new HashMap<>();
146
            // title的参数为ExportParams类型,目前仅仅在ExportParams中设置了sheetName
147
            map.put("title", exportParams);
148
            // 模版导出对应得实体类型
149
            map.put("entity", PRPExcelEntity.class);
150
            // sheet中要填充得数据
151
            map.put("data", beans);
152
            sheetsList.add(map);
153
        }
154
        // 执行方法
155
        Workbook workBook = ExcelExportUtil.exportExcel(sheetsList, ExcelType.HSSF);
156
        workBook.createCellStyle().setLocked(true);
157
        ExcelDelegate.exportExcel(workBook, "考点考场人员信息.xls", response);
158
159
    }
30
160
31
}
161
}

+ 5 - 0
oa-app/src/main/java/com/css/oa/exam/room/repository/IRoomRepository.java

36
    @Query("select r from Room r where r.create_unit_id in :unitIds and r.place_id = :place_id and r.curr_unit_id = " + Unit.TOP_CODE)
36
    @Query("select r from Room r where r.create_unit_id in :unitIds and r.place_id = :place_id and r.curr_unit_id = " + Unit.TOP_CODE)
37
    List<Room> findAllByUnitIds(List<String> unitIds, String place_id);
37
    List<Room> findAllByUnitIds(List<String> unitIds, String place_id);
38
38
39
    @Modifying
40
    @Transactional
41
    @Query("select r.uuid from Room r where r.place_id = :place_id")
42
    List<String> findAllIdByPlace_id(@Param("place_id") String place_id);
43
39
}
44
}

+ 1 - 1
oa-app/src/main/java/com/css/oa/exam/score/service/ScoreService.java

274
            }
274
            }
275
            data.add(columns);
275
            data.add(columns);
276
        }
276
        }
277
277
        //原生POI
278
        //1.实例化HSSFWorkbook
278
        //1.实例化HSSFWorkbook
279
        HSSFWorkbook workbook = new HSSFWorkbook();
279
        HSSFWorkbook workbook = new HSSFWorkbook();
280
        //2.创建一个Excel表单,参数为sheet的名字
280
        //2.创建一个Excel表单,参数为sheet的名字

+ 34 - 0
oa-app/src/main/java/com/css/oa/exam/util/ExportHelper.java

1
package com.css.oa.exam.util;
2
3
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
4
5
import javax.servlet.http.HttpServletResponse;
6
import java.io.BufferedOutputStream;
7
import java.io.OutputStream;
8
9
public class ExportHelper {
10
11
    public static void export(HttpServletResponse response, HSSFWorkbook workbook,String fileName){
12
        try {
13
            //String fileName = "成绩分析-导出.xls";
14
            //清空response
15
            response.reset();
16
            //设置response的Header
17
            response.addHeader("Access-Control-Allow-Origin", "*");
18
            response.setHeader("Access-Control-Expose-Headers", "Content-Disposition");
19
            response.setCharacterEncoding("UTF-8");
20
            response.setHeader("content-Type", "application/vnd.ms-excel");
21
            response.addHeader("Content-Disposition", "attachment;filename=" + fileName);
22
23
            OutputStream os = new BufferedOutputStream(response.getOutputStream());
24
            //将excel写入到输出流中
25
            workbook.write(os);
26
            os.flush();
27
            os.close();
28
            System.out.println("设置浏览器下载成功!");
29
        } catch (Exception e) {
30
            System.out.println("设置浏览器下载失败!");
31
            e.printStackTrace();
32
        }
33
    }
34
}