From ce1b2967ffe3e33a929f7c537de8a374c789e3ac Mon Sep 17 00:00:00 2001
From: zouyu <2723363702@qq.com>
Date: 星期四, 07 五月 2026 15:15:26 +0800
Subject: [PATCH] ifs批次属性更新:修复接口报错

---
 inspect-server/src/main/java/com/ruoyi/inspect/service/impl/IfsPartPropsRecordServiceImpl.java |  102 ++++++++++++++++++++++++++++++++++----------------
 1 files changed, 69 insertions(+), 33 deletions(-)

diff --git a/inspect-server/src/main/java/com/ruoyi/inspect/service/impl/IfsPartPropsRecordServiceImpl.java b/inspect-server/src/main/java/com/ruoyi/inspect/service/impl/IfsPartPropsRecordServiceImpl.java
index 929e993..c51ed06 100644
--- a/inspect-server/src/main/java/com/ruoyi/inspect/service/impl/IfsPartPropsRecordServiceImpl.java
+++ b/inspect-server/src/main/java/com/ruoyi/inspect/service/impl/IfsPartPropsRecordServiceImpl.java
@@ -1,8 +1,13 @@
 package com.ruoyi.inspect.service.impl;
 
+import cn.hutool.core.util.ObjectUtil;
+import cn.hutool.json.JSONArray;
+import cn.hutool.json.JSONObject;
 import cn.hutool.json.JSONUtil;
+import com.alibaba.fastjson2.TypeReference;
 import com.baomidou.mybatisplus.core.toolkit.Wrappers;
 import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
+import com.ruoyi.basic.dto.IfsInventoryQuantityDto;
 import com.ruoyi.basic.mapper.IfsInventoryQuantityMapper;
 import com.ruoyi.basic.pojo.IfsInventoryQuantity;
 import com.ruoyi.common.core.domain.Result;
@@ -15,12 +20,14 @@
 import com.ruoyi.inspect.pojo.IfsSplitOrderRecord;
 import com.ruoyi.inspect.service.IfsPartPropsRecordService;
 import lombok.extern.slf4j.Slf4j;
+import org.apache.commons.lang3.ObjectUtils;
 import org.apache.commons.lang3.StringUtils;
 import org.springframework.beans.factory.annotation.Autowired;
-import org.springframework.beans.factory.annotation.Value;
 import org.springframework.stereotype.Service;
+import org.springframework.transaction.annotation.Isolation;
 import org.springframework.transaction.annotation.Transactional;
 
+import java.math.BigDecimal;
 import java.util.*;
 
 /**
@@ -42,8 +49,8 @@
     @Autowired
     private IfsSplitOrderRecordMapper ifsSplitOrderRecordMapper;
 
-    @Value("${ifs.contract}")
-    public String contract;
+    @Autowired
+    private IfsPartPropsRecordMapper ifsPartPropsRecordMapper;
 
     @Override
     @Transactional(rollbackFor = Exception.class)
@@ -51,38 +58,36 @@
         if(Objects.isNull(ifsPartPropsRecord)){
             throw new RuntimeException("鍙傛暟涓嶈兘涓虹┖");
         }
-        //鏌ヨ鏄惁宸叉湁鍚屾壒娆″悓闆朵欢鍙风殑鎵规灞炴�э紝娌℃湁鎵嶆洿鏂�
-        Long count = baseMapper.selectCountByPartNoAndLotBatchNo(ifsPartPropsRecord.getPartNo(),ifsPartPropsRecord.getLotBatchNo());
-        if(count==0){
-            //鍒ゆ柇鏄柊澧炶繕鏄洿鏂�
-            String actionType = Objects.isNull(ifsPartPropsRecord.getId())?"New":"Modify";
-            Map<String, Object> inAttrMap = new HashMap<>();
-            inAttrMap.put("RECORD_ID", UUID.randomUUID().toString());
-            inAttrMap.put("SYSCODE", "LIMS");
-            inAttrMap.put("SYSMODEL", "搴撳瓨鐗╂枡鎵规灞炴�т慨鏀�");
-            HashMap<String, Object> batchInfoMap = new HashMap<>();
-            batchInfoMap.put("CONTRACT",contract);//鍩�
-            batchInfoMap.put("PART_NO",ifsPartPropsRecord.getPartNo());//闆朵欢鍙�
-            batchInfoMap.put("LOT_BATCH_NO",ifsPartPropsRecord.getLotBatchNo());//鎵规鍙�
-            batchInfoMap.put("ATTR1",ifsPartPropsRecord.getDrumNo());//杞藉叿缂栧彿
-            batchInfoMap.put("ATTR2",ifsPartPropsRecord.getStartMeterMark().toString());//璧峰绫虫爣
-            batchInfoMap.put("ATTR3",ifsPartPropsRecord.getEndMeterMark().toString());//鎴绫虫爣
-            batchInfoMap.put("ATTR4", ifsPartPropsRecord.getOuterColor());//澶栨姢棰滆壊
-            batchInfoMap.put("ATTR5",ifsPartPropsRecord.getInsulationColor());//缁濈紭棰滆壊
-            batchInfoMap.put("ATTR8",ifsPartPropsRecord.getLetteringInfo());//鍗板瓧淇℃伅
-            batchInfoMap.put("ATTR23","杞﹂棿璁㈠崟");//鍏ュ簱鏉ユ簮
-            batchInfoMap.put("ATTR24","0");//鍒嗗壊棰勭暀鏁伴噺
-            batchInfoMap.put("ACTION_TYPE",actionType);//鎿嶄綔绫诲瀷
-            inAttrMap.put("BATCH_INFO", Collections.singletonList(batchInfoMap));
-            Result result = ifsApiUtils.importPartLotAttr(JSONUtil.toJsonStr(inAttrMap));
-            if(result.getCode()!=200){
-                throw new RuntimeException("搴撳瓨鐗╂枡鎵规灞炴�ф洿鏂板け璐ワ細"+result.getMessage());
-            }
+        //鍒ゆ柇鏄柊澧炶繕鏄洿鏂�
+        String actionType = Objects.isNull(ifsPartPropsRecord.getId())?"New":"Modify";
+        Map<String, Object> inAttrMap = new HashMap<>();
+        inAttrMap.put("RECORD_ID", UUID.randomUUID().toString());
+        inAttrMap.put("SYSCODE", "LIMS");
+        inAttrMap.put("SYSMODEL", "搴撳瓨鐗╂枡鎵规灞炴�т慨鏀�");
+        HashMap<String, Object> batchInfoMap = new HashMap<>();
+        batchInfoMap.put("CONTRACT",ifsPartPropsRecord.getContract());//鍩�
+        batchInfoMap.put("PART_NO",ifsPartPropsRecord.getPartNo());//闆朵欢鍙�
+        batchInfoMap.put("LOT_BATCH_NO",ifsPartPropsRecord.getLotBatchNo());//鎵规鍙�
+        batchInfoMap.put("ATTR1",ifsPartPropsRecord.getDrumNo());//杞藉叿缂栧彿
+        batchInfoMap.put("ATTR2",ifsPartPropsRecord.getStartMeterMark().toString());//璧峰绫虫爣
+        batchInfoMap.put("ATTR3",ifsPartPropsRecord.getEndMeterMark().toString());//鎴绫虫爣
+        batchInfoMap.put("ATTR4", ifsPartPropsRecord.getOuterColor());//澶栨姢棰滆壊
+        batchInfoMap.put("ATTR5",ifsPartPropsRecord.getInsulationColor());//缁濈紭棰滆壊
+        batchInfoMap.put("ATTR8",ifsPartPropsRecord.getLetteringInfo());//鍗板瓧淇℃伅
+        batchInfoMap.put("ATTR23","杞﹂棿璁㈠崟");//鍏ュ簱鏉ユ簮
+        batchInfoMap.put("ATTR24","0");//鍒嗗壊棰勭暀鏁伴噺
+        batchInfoMap.put("ACTION_TYPE",actionType);//鎿嶄綔绫诲瀷
+        inAttrMap.put("BATCH_INFO", Collections.singletonList(batchInfoMap));
+        Result result = ifsApiUtils.importPartLotAttr(ifsPartPropsRecord.getContract(),JSONUtil.toJsonStr(inAttrMap));
+        if(result.getCode()!=200){
+            throw new RuntimeException("搴撳瓨鐗╂枡鎵规灞炴�ф洿鏂板け璐ワ細"+result.getMessage());
         }
         return this.saveOrUpdate(ifsPartPropsRecord);
     }
 
+
     @Override
+    @Transactional(rollbackFor = Exception.class,isolation = Isolation.READ_COMMITTED)
     public IfsPartPropsRecord getOneByIfsId(Long ifsId) {
         //鏌ヨifs璁㈠崟淇℃伅
         IfsInventoryQuantity ifsInventoryQuantity = ifsInventoryQuantityMapper.selectById(ifsId);
@@ -109,11 +114,42 @@
             ifsPartPropsRecord.setLetteringInfo(splitRecord.getLetteringInfo());
             ifsPartPropsRecord.setInsulationColor(splitRecord.getInsulationColor());
             ifsPartPropsRecord.setOuterColor(splitRecord.getOuterColor());
-            ifsPartPropsRecord.setDrumNo(splitRecord.getDrumNo());
-            ifsPartPropsRecord.setDrumNo(splitRecord.getDrumNo());
             return ifsPartPropsRecord;
         }
-        return this.getOne(Wrappers.<IfsPartPropsRecord>lambdaQuery().eq(IfsPartPropsRecord::getIfsInventoryId,ifsId).last("limit 1"));
+        //鏌ヨ鎵规灞炴�ц褰�
+        IfsPartPropsRecord propsRecord = this.getOne(Wrappers.<IfsPartPropsRecord>lambdaQuery().eq(IfsPartPropsRecord::getIfsInventoryId, ifsId).last("limit 1"));
+        if(ObjectUtil.isNotEmpty(propsRecord)){
+            return propsRecord;
+        }
+        //鏌ヨifs鎵规灞炴�ц褰曪紝鏈夊氨鍏堟柊澧炲埌鏁版嵁搴�
+        Map<String, Object> queryMap = new HashMap<>();
+        queryMap.put("LOT_BATCH_NO",ifsInventoryQuantity.getUpdateBatchNo());
+        queryMap.put("PART_NO",ifsInventoryQuantity.getPartNo());
+        Result queryPartLotResult = ifsApiUtils.queryPartLotAttr(ifsInventoryQuantity.getContract(), JSONUtil.toJsonStr(queryMap));
+        if(queryPartLotResult.getCode()==200){
+            JSONObject entries = JSONUtil.parseObj(queryPartLotResult.getData());
+            JSONArray listInfo = entries.getJSONArray("LIST_INFO");
+            if(!listInfo.isEmpty()){
+                Map<String,Object> parseObject = com.alibaba.fastjson2.JSONObject.parseObject(JSONUtil.toJsonStr(listInfo.get(0)), new TypeReference<Map<String, Object>>() {}.getType());
+                IfsPartPropsRecord ifsPartPropsRecord = new IfsPartPropsRecord();
+                ifsPartPropsRecord.setIfsInventoryId(ifsInventoryQuantity.getId());//ifs璁㈠崟id
+                ifsPartPropsRecord.setDrumNo(parseObject.get("ATTR1").toString());//杞藉叿缂栧彿
+                BigDecimal startMeterMark = ObjectUtils.isNotEmpty(parseObject.get("ATTR2"))?new BigDecimal(parseObject.get("ATTR2").toString()):BigDecimal.ZERO;
+                BigDecimal endMeterMark = ObjectUtils.isNotEmpty(parseObject.get("ATTR3"))?new BigDecimal(parseObject.get("ATTR3").toString()):BigDecimal.ZERO;
+                ifsPartPropsRecord.setStartMeterMark(startMeterMark);//璧峰绫虫爣
+                ifsPartPropsRecord.setEndMeterMark(endMeterMark);//鎴绫虫爣
+                ifsPartPropsRecord.setOuterColor(parseObject.get("ATTR4").toString());//澶栨姢棰滆壊
+                ifsPartPropsRecord.setInsulationColor(parseObject.get("ATTR5").toString());//缁濈紭棰滆壊
+                ifsPartPropsRecord.setLetteringInfo(parseObject.get("ATTR8").toString());//鍗板瓧淇℃伅
+                ifsPartPropsRecordMapper.insert(ifsPartPropsRecord);
+            }
+        }
+        return this.getOne(Wrappers.<IfsPartPropsRecord>lambdaQuery().eq(IfsPartPropsRecord::getIfsInventoryId, ifsId).last("limit 1"));
+    }
+
+    @Override
+    public IfsPartPropsRecordDTO getOneByContract(IfsInventoryQuantityDto ifsInventoryQuantityDto) {
+        return baseMapper.selectOneByContract(ifsInventoryQuantityDto);
     }
 }
 

--
Gitblit v1.9.3