yangys
2024-01-29 3ef1c88e46ba88f46e70377b158062096dd286e0
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
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
package com.qianwen.mdc.service;
 
import java.text.DateFormat;
import java.text.SimpleDateFormat;
import java.util.List;
 
import org.springframework.beans.BeanUtils;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.scheduling.annotation.Async;
import org.springframework.scheduling.annotation.Scheduled;
import org.springframework.stereotype.Component;
 
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.baomidou.mybatisplus.core.toolkit.Wrappers;
import com.qianwen.mdc.domain.Machine;
import com.qianwen.mdc.domain.MachineAccount;
import com.qianwen.mdc.domain.MachineStatus;
import com.qianwen.mdc.domain.MachineStatusHistory;
import com.qianwen.mdc.domain.MachineUtilization;
import com.qianwen.mdc.domain.Section;
import com.qianwen.mdc.domain.workshop.Workshop;
import com.qianwen.mdc.mapper.MachineAccountMapper;
import com.qianwen.mdc.mapper.MachineMapper;
import com.qianwen.mdc.mapper.MachineStatusHistoryMapper;
import com.qianwen.mdc.mapper.MachineStatusMapper;
import com.qianwen.mdc.mapper.MdcUtilizationMapper;
import com.qianwen.mdc.mapper.SectionMapper;
import com.qianwen.mdc.mapper.WorkshopMapper;
import com.qianwen.mdc.utils.TimestampUtil;
 
 
/**
 * 数据归档服务,将 machine_status 数据导入machine_status_history表,并加入最新的machine_status数据
 */
@Component
@Async
public class MdcDataArchiveService {
 
    @Autowired
    private MachineMapper machineMapper;
    @Autowired
    private WorkshopMapper workshopMapper;
    @Autowired
    private SectionMapper sectionMapper;
    @Autowired
    private MachineStatusMapper machineStatusMapper;
    @Autowired
    private MachineStatusHistoryMapper machineStatusHistoryMapper;
   
    @Autowired
    private MachineAccountMapper machineAccountMapper;
    @Autowired
    private MdcUtilizationMapper mdcUtilizationMapper;
 
    
    
    @Scheduled(cron = "0 10 8 * * ?")
    public void dataArchive() {
        int dayStart = (int) TimestampUtil.getShiftDayStartTimestamp();
        /*
        Example statusExample = new Example(MdcMachineStatus.class);
        statusExample.createCriteria().andLessThan("time", dayStart);
        List<MdcMachineStatus> mdcMachineStatusList = mdcMachineStatusMapper.selectByExample(statusExample);
        */
        LambdaQueryWrapper<MachineStatus> wrapper = Wrappers.lambdaQuery();
        wrapper.lt(MachineStatus::getTime, dayStart);
        
        List<MachineStatus> machineStatusList = machineStatusMapper.selectList(wrapper);
       
        for (MachineStatus status : machineStatusList) {
            MachineStatusHistory statusHistory = new MachineStatusHistory();
            BeanUtils.copyProperties(status, statusHistory);
            statusHistory.setId(null);
            
            machineStatusHistoryMapper.insert(statusHistory);
            machineStatusMapper.deleteById(status.getId());
            
            MachineUtilization mdcUtilization = new MachineUtilization();
            mdcUtilization.setId(null);
            /*
            Example accountExample = new Example(MdcMachineAccount.class);
            accountExample.setOrderByClause("id desc");
            accountExample.createCriteria().andEqualTo("machineId", status.getMachineId());
            RowBounds rowBounds = new RowBounds(0, 1);
            List<MdcMachineAccount> list = mdcMachineAccountMapper.selectByExampleAndRowBounds(accountExample, rowBounds);
            */
            QueryWrapper<MachineAccount> wrapperAcc = Wrappers.query();
            wrapperAcc.eq("machine_id", status.getMachineId());
            wrapperAcc.orderByDesc("id");
            
            //List<MdcMachineAccount> list = mdcMachineAccountMapper.selectList(wrapperAcc);
            List<MachineAccount> list = machineAccountMapper.lastByMachineId(status.getMachineId());
            if (list.isEmpty()) {
                continue;
            }
            MachineAccount account = list.get(0);
            
            //统计利用率数据并入库
            mdcUtilization.setUid(account.getUuid());
            mdcUtilization.setName(account.getCategory());
            //mdcUtilization.setModel(account.getModel());
            //TODO 设备类型??如果是,就是mdcUtilization.setModel(account.getType());
            //mdcUtilization.setCategory(account.getType());
            mdcUtilization.setModel(account.getType());
            mdcUtilization.setCategory(account.getCategory());
            
            
            mdcUtilization.setCncSystem(account.getCncSystem());
 
            Machine machine = machineMapper.selectById(status.getMachineId());
            Workshop workshop = workshopMapper.selectById(machine.getWorkshopId());
            Section section = sectionMapper.selectById(machine.getSectionId());
            if(workshop != null) {
                mdcUtilization.setWorkshop(workshop.getName());
            }
            
            if(section != null) {
                mdcUtilization.setSection(section.getName());
            }
            mdcUtilization.setShift(machine.getShiftType());
 
            DateFormat df = new SimpleDateFormat("yyyyMMdd");
            mdcUtilization.setCdate(df.format((long) status.getTime() * 1000));
 
            //mdcUtilization.setCutTime(Integer.valueOf(status.getVar2()));
            mdcUtilization.setCutTime(status.getCycleTime());
            //mdcUtilization.setBootTime(Integer.valueOf(status.getVar3()));
            mdcUtilization.setBootTime(status.getMachineOnTime());
            
            String downTime = status.getVar8();
            if ("".equals(downTime)) {
                mdcUtilization.setDownTime(0);
            } else {
                mdcUtilization.setDownTime(Integer.valueOf(status.getVar8()));
            }
            mdcUtilization.setThreeShiftTime(3600 * 21);
            mdcUtilization.setTwoShiftTime((int) (3600 * 15.5));
            mdcUtilization.setFactory(2);
 
            mdcUtilizationMapper.insert(mdcUtilization);
        }
 
    }
 
}