From 7bee802c37d290a38be32012d84a3e5bc8b4ea92 Mon Sep 17 00:00:00 2001
From: 懒羊羊 <15939171744@163.com>
Date: 星期二, 09 四月 2024 08:50:46 +0800
Subject: [PATCH] -

---
 jcdm-main/src/main/java/com/jcdm/main/da/paramCollection/service/impl/DaParamCollectionServiceImpl.java |  140 ++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 138 insertions(+), 2 deletions(-)

diff --git a/jcdm-main/src/main/java/com/jcdm/main/da/paramCollection/service/impl/DaParamCollectionServiceImpl.java b/jcdm-main/src/main/java/com/jcdm/main/da/paramCollection/service/impl/DaParamCollectionServiceImpl.java
index 68dda81..3652b6a 100644
--- a/jcdm-main/src/main/java/com/jcdm/main/da/paramCollection/service/impl/DaParamCollectionServiceImpl.java
+++ b/jcdm-main/src/main/java/com/jcdm/main/da/paramCollection/service/impl/DaParamCollectionServiceImpl.java
@@ -1,15 +1,33 @@
 package com.jcdm.main.da.paramCollection.service.impl;
 
 import cn.hutool.core.date.DateUtil;
+import cn.hutool.db.Db;
+import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
+import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
 import com.jcdm.common.utils.DateUtils;
+import com.jcdm.main.bs.formula.service.IBsFormulaInfoService;
+import com.jcdm.main.bs.formula.service.impl.BsFormulaInfoServiceImpl;
+import com.jcdm.main.bs.formulaChild.domain.BsFormulaChildInfo;
+import com.jcdm.main.bs.formulaChild.mapper.BsFormulaChildInfoMapper;
+import com.jcdm.main.bs.formulaChild.service.IBsFormulaChildInfoService;
 import com.jcdm.main.da.collectionParamConf.domain.DaCollectionParamConf;
 import com.jcdm.main.da.collectionParamConf.mapper.DaCollectionParamConfMapper;
 import com.jcdm.main.da.paramCollection.domain.DaParamCollection;
 import com.jcdm.main.da.paramCollection.mapper.DaParamCollectionMapper;
 import com.jcdm.main.da.paramCollection.service.IDaParamCollectionService;
+import com.jcdm.main.da.passingStationCollection.domain.DaPassingStationCollection;
+import com.jcdm.main.da.passingStationCollection.mapper.DaPassingStationCollectionMapper;
+import com.jcdm.main.da.passingStationCollection.service.IDaPassingStationCollectionService;
+import com.jcdm.main.plcserver.sub.OPCUaSubscription;
+import com.kangaroohy.milo.model.ReadWriteEntity;
+import com.kangaroohy.milo.service.MiloService;
+import org.apache.ibatis.session.ExecutorType;
+import org.apache.ibatis.session.SqlSession;
+import org.apache.ibatis.session.SqlSessionFactory;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.stereotype.Service;
 
+import javax.annotation.Resource;
 import java.util.*;
 
 /**
@@ -19,13 +37,28 @@
  * @date 2023-12-13
  */
 @Service
-public class DaParamCollectionServiceImpl implements IDaParamCollectionService
+public class DaParamCollectionServiceImpl extends ServiceImpl<DaParamCollectionMapper,DaParamCollection> implements IDaParamCollectionService
 {
     @Autowired
     private DaParamCollectionMapper daParamCollectionMapper;
 
     @Autowired
     private DaCollectionParamConfMapper daCollectionParamConfMapper;
+
+    @Autowired
+    private BsFormulaChildInfoMapper bsFormulaChildInfoMapper;
+
+    @Autowired
+    private IBsFormulaChildInfoService bsFormulaChildInfoService;
+
+    @Autowired
+    private MiloService miloService;
+
+    @Autowired
+    private DaPassingStationCollectionMapper daPassingStationCollectionMapper;
+
+    @Resource
+    private SqlSessionFactory sqlSessionFactory;
 
     /**
      * 鏌ヨ璁惧浜у搧杩囩▼鍙傛暟閲囬泦
@@ -49,6 +82,27 @@
     public List<DaParamCollection> selectDaParamCollectionList(DaParamCollection daParamCollection)
     {
         return daParamCollectionMapper.selectDaParamCollectionList(daParamCollection);
+    }
+
+    @Override
+    public void saveBeachDaParamCollection(List<DaParamCollection> list) {
+        // ExecutorType.SIMPLE: 杩欎釜鎵ц鍣ㄧ被鍨嬩笉鍋氱壒娈婄殑浜嬫儏銆傚畠涓烘瘡涓鍙ョ殑鎵ц鍒涘缓涓�涓柊鐨勯澶勭悊璇彞銆�
+        // ExecutorType.REUSE: 杩欎釜鎵ц鍣ㄧ被鍨嬩細澶嶇敤棰勫鐞嗚鍙ャ��
+        // ExecutorType.BATCH: 杩欎釜鎵ц鍣ㄤ細鎵归噺鎵ц鎵�鏈夋洿鏂拌鍙�,濡傛灉 SELECT 鍦ㄥ畠浠腑闂存墽琛岃繕浼氭爣瀹氬畠浠槸 蹇呴』鐨�,鏉ヤ繚璇佷竴涓畝鍗曞苟鏄撲簬鐞嗚В鐨勮涓恒��
+
+        // 鍏抽棴session鐨勮嚜鍔ㄦ彁浜�
+        SqlSession sqlSession = sqlSessionFactory.openSession(ExecutorType.BATCH, false);
+        try {
+            DaParamCollectionMapper userMapper = sqlSession.getMapper(DaParamCollectionMapper.class);
+            list.stream().forEach(DaParamCollection -> userMapper.insertDaParamCollection(DaParamCollection));
+            // 鎻愪氦鏁版嵁
+            sqlSession.commit();
+            sqlSession.rollback();
+        } catch (Exception e) {
+            sqlSession.rollback();
+        } finally {
+            sqlSession.close();
+        }
     }
 
     /**
@@ -118,11 +172,11 @@
             daCollectionParamConf.setProcessesCode(daParamCollection.getLocationCode());
             daCollectionParamConf.setCollectParameterId(key);
             List<DaCollectionParamConf> daCollectionParamConfs = daCollectionParamConfMapper.selectDaCollectionParamConfList(daCollectionParamConf);
-
             DaParamCollection saveData = new DaParamCollection();
             saveData.setWorkOrderNo(daParamCollection.getWorkOrderNo());
             saveData.setProductCode(daParamCollection.getProductCode());
             saveData.setLocationCode(daParamCollection.getLocationCode());
+            saveData.setSfcCode(daParamCollection.getProductBarcode());
             saveData.setParamCode(daCollectionParamConfs.get(0).getCollectParameterId());
             saveData.setParamName(daCollectionParamConfs.get(0).getCollectParameterName());
             saveData.setCollectionTime(new Date());
@@ -130,4 +184,86 @@
             daParamCollectionMapper.insertDaParamCollection(saveData);
         });
     }
+
+    @Override
+    public void addTighteningParameters(DaParamCollection daParamCollection) {
+        String tightenData = daParamCollection.getTightenTheArray();
+        tightenData = tightenData.replace("[", "").replace("]", "").replace(" ", "");
+        String[] tightenDataParts = tightenData.split(",");
+        String paramCode = daParamCollection.getParamCode();
+        String[] paramCodeParts = paramCode.split(",");
+        for (int i = 0; i < paramCodeParts.length; i++) {
+            daParamCollection.setParamValue(tightenDataParts[i]);
+            daParamCollection.setParamCode(paramCodeParts[i]);
+            daParamCollection.setCollectionTime(new Date());
+            daParamCollection.setSfcCode(daParamCollection.getProductBarcode());
+            daParamCollectionMapper.insertDaParamCollection(daParamCollection);
+        }
+    }
+
+    @Override
+    public void saveCampaignTimeParameters(DaParamCollection daParamCollection) {
+        List<BsFormulaChildInfo> list = bsFormulaChildInfoService.list(new LambdaQueryWrapper<BsFormulaChildInfo>()
+                .eq(BsFormulaChildInfo::getProcessesCode, daParamCollection.getLocationCode())
+                .eq(BsFormulaChildInfo::getSpareField4, "1")
+        );
+        if(!list.get(0).getResults().equals("OK")){
+            try {
+                miloService.writeToOpcShort(ReadWriteEntity.builder().identifier("PACK."+daParamCollection.getLocationCode()+".RecordDataDone").value(22).build());
+            } catch (Exception e) {
+                throw new RuntimeException(e);
+            }
+            return;
+        }
+        BsFormulaChildInfo bsFormulaChildInfo = new BsFormulaChildInfo();
+        bsFormulaChildInfo.setProcessesCode(daParamCollection.getLocationCode());
+        bsFormulaChildInfo.setProductCode(daParamCollection.getProductCode());
+        bsFormulaChildInfo.setSpareField4("1");
+        List<BsFormulaChildInfo> bsFormulaChildInfos = bsFormulaChildInfoMapper.selectBsFormulaChildInfoList(bsFormulaChildInfo);
+        String result = bsFormulaChildInfos.get(0).getResults();
+        if(result != null && !result.isEmpty()){
+            try {
+                //杩囩珯鍙傛暟閲囬泦璁板綍鍑虹珯鏃堕棿
+                DaCollectionParamConf daCollectionParamConf = new DaCollectionParamConf();
+                daCollectionParamConf.setProcessesCode(daParamCollection.getLocationCode());
+                daCollectionParamConf.setCollectParameterId("OUTT");
+                List<DaCollectionParamConf> daCollectionParamConfs = daCollectionParamConfMapper.selectDaCollectionParamConfList(daCollectionParamConf);
+                DaParamCollection saveData = new DaParamCollection();
+                saveData.setWorkOrderNo(daParamCollection.getWorkOrderNo());
+                saveData.setProductCode(daParamCollection.getProductCode());
+                saveData.setLocationCode(daParamCollection.getLocationCode());
+                saveData.setSfcCode(daParamCollection.getProductBarcode());
+                saveData.setParamCode(daCollectionParamConfs.get(0).getCollectParameterId());
+                saveData.setParamName(daCollectionParamConfs.get(0).getCollectParameterName());
+                saveData.setCollectionTime(new Date());
+                saveData.setParamValue(DateUtil.formatDateTime(new Date()));
+                daParamCollectionMapper.insertDaParamCollection(saveData);
+
+                //鏇存柊杩囩珯璁板綍琛ㄥ嚭绔欐椂闂�
+                DaPassingStationCollection daPassingStationCollection = new DaPassingStationCollection();
+                daPassingStationCollection.setWorkOrderNo(daParamCollection.getWorkOrderNo());
+                daPassingStationCollection.setLocationCode(daParamCollection.getLocationCode());
+                List<DaPassingStationCollection> daPassingStationCollections = daPassingStationCollectionMapper.selectDaPassingStationCollectionList(daPassingStationCollection);
+                daPassingStationCollections.get(0).setOutboundTime(new Date());
+                int i = daPassingStationCollectionMapper.updateDaPassingStationCollection(daPassingStationCollections.get(0));
+
+//                OPCUaSubscription.SaveParamData(daParamCollection.getProductBarcode(),"OP",daParamCollection.getLocationCode(),daParamCollection.getWorkOrderNo(),daParamCollection.getProductCode());
+
+                //缁檕pc鍙�21
+                miloService.writeToOpcShort(ReadWriteEntity.builder().identifier("PACK."+daParamCollection.getLocationCode()+".RecordDataDone").value(21).build());
+            } catch (Exception e) {
+                throw new RuntimeException(e);
+            }
+        }
+    }
+
+    @Override
+    public void insertBatch(List<DaParamCollection> confList){
+        try{
+            this.saveBatch(confList);
+        }catch (Exception e){
+            return;
+        }
+
+    }
 }

--
Gitblit v1.9.3