From d3234825d804a6a205dba1c6092acc8e29981b81 Mon Sep 17 00:00:00 2001
From: lfd <1>
Date: 星期四, 06 三月 2025 10:11:23 +0800
Subject: [PATCH] #

---
 src/main/java/com/zy/ints/task/scheduler/ErpDetTbScheduler.java |   74 ++++++++++++++++++++++++++++--------
 1 files changed, 57 insertions(+), 17 deletions(-)

diff --git a/src/main/java/com/zy/ints/task/scheduler/ErpDetTbScheduler.java b/src/main/java/com/zy/ints/task/scheduler/ErpDetTbScheduler.java
index 0b0c5f8..0e41258 100644
--- a/src/main/java/com/zy/ints/task/scheduler/ErpDetTbScheduler.java
+++ b/src/main/java/com/zy/ints/task/scheduler/ErpDetTbScheduler.java
@@ -1,12 +1,10 @@
 package com.zy.ints.task.scheduler;
 
+import com.baomidou.mybatisplus.mapper.EntityWrapper;
 import com.core.common.Cools;
 import com.core.common.DateUtils;
 import com.core.common.SnowflakeIdWorker;
-import com.zy.asrs.entity.DocType;
-import com.zy.asrs.entity.Mat;
-import com.zy.asrs.entity.Order;
-import com.zy.asrs.entity.OrderDetl;
+import com.zy.asrs.entity.*;
 import com.zy.asrs.service.*;
 import com.zy.ints.entity.ErpDetTb;
 import com.zy.ints.entity.ErpDetTbBak;
@@ -59,7 +57,7 @@
     @Scheduled(cron = "${erp.refreshtime}")
     public void InOrOutOrder() {
         if (!erpEnabledErpDetTb) return;
-        String sqlSelectErpDetTb = "select BIL_NO as billNo,prd_no as prdNo,ITM as itm,ADD_ID as addId2,QTY as qty,PRD_MARK as prdMark,WH as wh,BIL_DATE as billdate,STATUS as status,Temp1 as temp1,Temp2 as temp2,Temp3 as temp3 from ERP_DETTB where 1=1";
+        String sqlSelectErpDetTb = "select BIL_NO as billNo,prd_no as prdNo,ITM as itm,ADD_ID as addId2,QTY as qty,PRD_MARK as prdMark,WH as wh,STATUS as status,Temp1 as temp1,Temp2 as temp2,Temp3 as temp3 from ERP_DETTB where 1=1";
         String sqlUpDateErpDetTbOne = "update ERP_DETTB set STATUS=1 where 1=1 and PRD_NO=";
         String sqlUpDateErpDetTbTwo = "update ERP_DETTB set STATUS=2 ";
 
@@ -72,14 +70,19 @@
                     if (status == 0) {
                         Mat mat = matService.selectByMatnr(erpDetTb.getPrdNo());
                         if (Cools.isEmpty(mat)) {
-                            erpSqlServer.update(sqlUpDateErpDetTbTwo + ",Temp1='鍝佸彿淇℃伅鍦ㄧ珛搴撲笉瀛樺湪锛岃鍏堟坊鍔犲晢鍝侊紒锛侊紒'" + "where 1=1 and PRD_NO=" + "'" + erpDetTb.getPrdNo() + "'");
-                            callApiLogSave(erpDetTb, "ERP_DETTB", "鍝佸彿淇℃伅鍦ㄧ珛搴撲笉瀛樺湪锛岃鍏堟坊鍔犲晢鍝侊紒锛侊紒", false);
+                            if(Cools.isEmpty(erpDetTb.getTemp1())){
+                                erpSqlServer.update(sqlUpDateErpDetTbTwo + ",Temp1='鍝佸彿淇℃伅鍦ㄧ珛搴撲笉瀛樺湪锛岃鍏堟坊鍔犲晢鍝侊紒锛侊紒'" + "where 1=1 "
+                                        +" and PRD_NO=" + "'" + erpDetTb.getPrdNo() + "'"
+                                        +" and ITM=" + "'" + erpDetTb.getItm() + "'"
+                                        +" and BIL_NO=" + "'" + erpDetTb.getBillNo() + "'");
+                                callApiLogSave(erpDetTb, "ERP_DETTB", "鍝佸彿淇℃伅鍦ㄧ珛搴撲笉瀛樺湪锛岃鍏堟坊鍔犲晢鍝侊紒锛侊紒", false);
+                            }
                         } else {
-                            Order order = orderService.selectByNo(erpDetTb.getBillNo());
+                            Order order = orderService.selectByNo(erpDetTb.getBillNo()+"---"+erpDetTb.getItm());
                             if (Cools.isEmpty(order)) {
                                 order = new Order(
                                         String.valueOf(snowflakeIdWorker.nextId()),    // 缂栧彿[闈炵┖]
-                                        erpDetTb.getBillNo(),    // 璁㈠崟缂栧彿
+                                        erpDetTb.getBillNo()+"---"+erpDetTb.getItm(),    // 璁㈠崟缂栧彿
                                         DateUtils.convert(now),    // 鍗曟嵁鏃ユ湡
                                         null,    // 鍗曟嵁绫诲瀷
                                         null,    // 椤圭洰缂栧彿
@@ -113,8 +116,8 @@
                                         now,    // 淇敼鏃堕棿
                                         null    // 澶囨敞
                                 );
-                                String InAndOut = erpDetTb.getAddId2()==2 ? "锛堝嚭搴擄級" : "锛堝叆搴擄級";
-                                DocType docType = docTypeService.selectOrAdd("ERP璁㈠崟"+InAndOut, erpDetTb.getAddId().equals("1"));
+                                String InAndOut = erpDetTb.getAddId2().equals(2) ? "锛堝嚭搴擄級" : "锛堝叆搴擄級";
+                                DocType docType = docTypeService.selectOrAdd("ERP璁㈠崟"+InAndOut, erpDetTb.getAddId2().equals(1));
                                 if (!Cools.isEmpty(docType)) {
                                     order.setDocType(docType.getDocId());
                                     if (!orderService.insert(order)) {
@@ -125,13 +128,14 @@
                                     }
                                 }
                             }
-                            Order order1 = orderService.selectByNo(erpDetTb.getBillNo());
+                            Order order1 = orderService.selectByNo(erpDetTb.getBillNo()+"---"+erpDetTb.getItm());
                             if (!Cools.isEmpty(order1)) {
-                                OrderDetl orderDetl = orderDetlService.selectItem(order1.getId(), erpDetTb.getBillNo(), erpDetTb.getPrdMark());
+//                                OrderDetl orderDetl = orderDetlService.selectItem(order1.getId(), erpDetTb.getBillNo(), erpDetTb.getPrdMark());
+                                OrderDetl orderDetl = orderDetlService.selectOne(new EntityWrapper<OrderDetl>().eq("order_no",erpDetTb.getBillNo()+"---"+erpDetTb.getItm()).eq("matnr",erpDetTb.getPrdNo()));
                                 if (Cools.isEmpty(orderDetl)) {
                                     orderDetl = new OrderDetl();
                                     orderDetl.setOrderId(order1.getId());
-                                    orderDetl.setOrderNo(erpDetTb.getBillNo());
+                                    orderDetl.setOrderNo(erpDetTb.getBillNo()+"---"+erpDetTb.getItm());
                                     orderDetl.setAnfme(erpDetTb.getQty());
                                     orderDetl.setQty(0.0D);
                                     orderDetl.setMatnr(erpDetTb.getPrdNo());
@@ -139,6 +143,7 @@
                                     orderDetl.setBatch(erpDetTb.getPrdMark());
                                     orderDetl.setSpecs(mat.getSpecs());
                                     orderDetl.setUnit(mat.getUnit());
+                                    orderDetl.setOrigin(erpDetTb.getItm().toString());
 
                                     orderDetl.setStatus(1);
                                     orderDetl.setCreateBy(9999L);
@@ -150,7 +155,36 @@
                                         erpSqlServer.update(sqlUpDateErpDetTbOne + "'" + erpDetTb.getPrdNo() + "'");
                                         callApiLogSave(erpDetTb, "ERP_DETTB", "鎺ユ敹ERP涓嬪彂璁㈠崟鎺ユ敹鎴愬姛锛侊紒", true);
                                     } else {
-                                        erpSqlServer.update(sqlUpDateErpDetTbTwo + ",temp1='娣诲姞璁㈠崟鏄庣粏妗eけ璐ワ紒锛侊紒'" + "where 1=1 and PRD_NO=" + "'" + erpDetTb.getPrdNo() + "'");
+                                        if (Cools.isEmpty(erpDetTb.getTemp2())){
+                                            erpSqlServer.update(sqlUpDateErpDetTbTwo + ",temp2='娣诲姞璁㈠崟鏄庣粏妗eけ璐ワ紒锛侊紒'" + "where 1=1 "
+                                                    +" and PRD_NO=" + "'" + erpDetTb.getPrdNo() + "'"
+                                                    +" and ITM=" + "'" + erpDetTb.getItm() + "'"
+                                                    +" and BIL_NO=" + "'" + erpDetTb.getBillNo() + "'");
+                                            callApiLogSave(erpDetTb, "ERP_DETTB", "ERP涓嬪彂璁㈠崟鎺ユ敹澶辫触锛侊紒", false);
+                                        }
+                                    }
+                                }else if (!erpDetTb.getItm().toString().equals(orderDetl.getOrigin())){
+                                    orderDetl.setAnfme(orderDetl.getAnfme()+erpDetTb.getQty());
+                                    EntityWrapper<OrderDetl> wrapper = new EntityWrapper<>();
+                                    wrapper.eq("id", orderDetl.getId());
+                                    if (orderDetlService.update(orderDetl,wrapper)) {
+                                        erpSqlServer.update(sqlUpDateErpDetTbOne + "'" + erpDetTb.getPrdNo() + "'");
+                                        callApiLogSave(erpDetTb, "ERP_DETTB", "鎺ユ敹ERP涓嬪彂璁㈠崟鎺ユ敹鎴愬姛锛侊紒", true);
+                                    } else {
+                                        if (Cools.isEmpty(erpDetTb.getTemp2())){
+                                            erpSqlServer.update(sqlUpDateErpDetTbTwo + ",temp2='鏇存柊璁㈠崟鏄庣粏妗eけ璐ワ紒锛侊紒'" + "where 1=1 "
+                                                    +" and PRD_NO=" + "'" + erpDetTb.getPrdNo() + "'"
+                                                    +" and ITM=" + "'" + erpDetTb.getItm() + "'"
+                                                    +" and BIL_NO=" + "'" + erpDetTb.getBillNo() + "'");
+                                            callApiLogSave(erpDetTb, "ERP_DETTB", "ERP涓嬪彂璁㈠崟鎺ユ敹澶辫触锛侊紒", false);
+                                        }
+                                    }
+                                }else {
+                                    if (Cools.isEmpty(erpDetTb.getTemp3())){
+                                        erpSqlServer.update(sqlUpDateErpDetTbTwo + ",temp3='鏇存柊璁㈠崟鏄庣粏妗eけ璐ワ紒锛侊紒璁㈠崟鏄庣粏宸插瓨鍦紒锛�'" + "where 1=1 "
+                                                +" and PRD_NO=" + "'" + erpDetTb.getPrdNo() + "'"
+                                                +" and ITM=" + "'" + erpDetTb.getItm() + "'"
+                                                +" and BIL_NO=" + "'" + erpDetTb.getBillNo() + "'");
                                         callApiLogSave(erpDetTb, "ERP_DETTB", "ERP涓嬪彂璁㈠崟鎺ユ敹澶辫触锛侊紒", false);
                                     }
                                 }
@@ -179,13 +213,19 @@
                         condition2.put("BIL_NO", "'" + erpDetTb.getBillNo() + "'");
                         condition2.put("PRD_NO", "'" + erpDetTb.getPrdNo() + "'");
                         condition2.put("ITM", "'" + erpDetTb.getItm() + "'");
-                        condition2.put("PRD_MARK", "'" + erpDetTb.getPrdMark() + "'");
+//                        condition2.put("PRD_MARK", "'" + erpDetTb.getPrdMark() + "'");
                         erpSqlServer.delete(ErpDetTb.class, condition2);
 
 //                        callApiLogSave(erpDetTb, "ERP_DETTB", "ERP涓嬪彂璁㈠崟澶囦唤鍚庡垹闄ゆ垚鍔燂紒锛�", true);
 
                     } else {
-                        callApiLogSave(erpDetTb, "ERP_DETTB", "鎺ユ敹ERP涓嬪彂璁㈠崟澶辫触锛侊紒锛佺姸鎬佸紓甯革紒锛侊紒", false);
+                        if (Cools.isEmpty(erpDetTb.getTemp1()) && Cools.isEmpty(erpDetTb.getTemp2()) && Cools.isEmpty(erpDetTb.getTemp3())){
+                            erpSqlServer.update(sqlUpDateErpDetTbTwo + ",Temp1='鎺ユ敹ERP涓嬪彂璁㈠崟澶辫触锛侊紒锛佺姸鎬佸紓甯革紒锛侊紒璇稥RP銆佺珛搴撳弻鏂瑰崗鍔╄В鍐炽��'" + "where 1=1 "
+                                    +" and PRD_NO=" + "'" + erpDetTb.getPrdNo() + "'"
+                                    +" and ITM=" + "'" + erpDetTb.getItm() + "'"
+                                    +" and BIL_NO=" + "'" + erpDetTb.getBillNo() + "'");
+                            callApiLogSave(erpDetTb, "ERP_DETTB", "鎺ユ敹ERP涓嬪彂璁㈠崟澶辫触锛侊紒锛佺姸鎬佸紓甯革紒锛侊紒", false);
+                        }
                     }
                 }
             }

--
Gitblit v1.9.1