whycxzp
2023-08-16 618fd4fe93cb0901011c59f05a4a68376b378fe2
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
package com.whyc.service;
 
import com.baomidou.mybatisplus.core.conditions.update.UpdateWrapper;
import com.baomidou.mybatisplus.core.toolkit.Wrappers;
import com.github.pagehelper.PageHelper;
import com.github.pagehelper.PageInfo;
import com.whyc.dto.Response;
import com.whyc.dto.paramter.DevAlarmPar;
import com.whyc.mapper.DevalarmDataHistoryMapper;
import com.whyc.pojo.BattalarmDataHistory;
import com.whyc.pojo.DevalarmDataHistory;
import com.whyc.pojo.UserInf;
import com.whyc.util.ActionUtil;
import com.whyc.util.SubTablePageInfoUtils;
import org.springframework.stereotype.Service;
 
import javax.annotation.Resource;
import java.text.ParseException;
import java.util.ArrayList;
import java.util.Calendar;
import java.util.Date;
import java.util.List;
 
@Service
public class DevalarmDataHistoryService {
 
    @Resource
    private DevalarmDataHistoryMapper mapper;
 
    @Resource
    private SubTablePageInfoUtils subTablePageInfoUtils;
 
    //设备告警历史查询
    public Response serchByCondition(DevAlarmPar par) {
        PageHelper.startPage(par.getPage().getPageCurr(), par.getPage().getPageSize());
        UserInf uinf = ActionUtil.getUser();
        par.setUId(uinf.getUId().intValue());
        List list = mapper.serchByCondition(par);
        PageInfo pageInfo = new PageInfo(list);
        List levelList = serchByLevel(uinf.getUId().intValue());
        return new Response().setII(1, pageInfo, levelList, "返回结果");
    }
 
    public Response getPageInfo(DevAlarmPar param) throws ParseException {
        Integer pageNum = param.getPage().getPageCurr();
        Integer pageSize = param.getPage().getPageSize();
        Date almStartTime = param.getAlmStartTime();
        Date almEndTime = param.getAlmStartTime1();
        UserInf uinf = ActionUtil.getUser();
        int uId = uinf.getUId().intValue();
        param.setUId(uId);
        PageInfo<Object> pageInfo = subTablePageInfoUtils.getPageInfo(pageNum, pageSize, almStartTime, almEndTime,
                "db_alarm", "tb_devalarm_data_history", param);
        List<Integer> levelList = subTablePageInfoUtils.getLevelList(uId,"db_alarm", "tb_devalarm_data_history", "tb_devalarm_data_history_?[0-9]*",null);
        return new Response().setII(1, pageInfo, levelList, "返回结果");
    }
 
    //查询分级告警的个数
    public List serchByLevel(int uId) {
        List list = new ArrayList();
        //分四级查询个数
        for (int i = 1; i <= 4; i++) {
            int countLevel = mapper.serchByLevel(i, uId);
            list.add(countLevel);
        }
        return list;
    }
 
    //设备告警删除告警
    public Response delete(int num) {
        UpdateWrapper wrapper = new UpdateWrapper();
        wrapper.eq("num", num);
        int flag = mapper.delete(wrapper);
        return new Response().set(flag);
    }
 
    public List<DevalarmDataHistory> getDataBeforeRetentionMonth(Date retentionTime) {
        return mapper.getDataBeforeRetentionMonth(retentionTime);
    }
 
    public void deleteBeforeRetentionMonth(Date retentionTime) {
        UpdateWrapper<DevalarmDataHistory> update = Wrappers.update();
 
        update.lt("alm_start_time",retentionTime);
        mapper.delete(update);
    }
}