From 421027f661437a0a452b09f372d9a47a8b6286ae Mon Sep 17 00:00:00 2001 From: LSH Date: 星期四, 23 二月 2023 09:54:10 +0800 Subject: [PATCH] # --- src/main/java/com/zy/ints/task/scheduler/ErpDetTbScheduler.java | 209 +++++++++++++++++++++++++++++++++++++++++++++++++--- 1 files changed, 196 insertions(+), 13 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 9c6d033..8911123 100644 --- a/src/main/java/com/zy/ints/task/scheduler/ErpDetTbScheduler.java +++ b/src/main/java/com/zy/ints/task/scheduler/ErpDetTbScheduler.java @@ -1,7 +1,13 @@ package com.zy.ints.task.scheduler; -import com.zy.asrs.service.MatService; +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.*; +import com.zy.asrs.service.*; import com.zy.ints.entity.ErpDetTb; +import com.zy.ints.entity.ErpDetTbBak; import com.zy.ints.erp.ErpSqlServer; import lombok.extern.slf4j.Slf4j; import org.springframework.beans.factory.annotation.Autowired; @@ -9,6 +15,9 @@ import org.springframework.scheduling.annotation.Scheduled; import org.springframework.stereotype.Component; +import java.text.SimpleDateFormat; +import java.util.Date; +import java.util.HashMap; import java.util.List; /** @@ -23,38 +32,212 @@ */ @Value("${erp.enabled}") private Boolean erpEnabled; + @Value("${erp.enabledErpDetTb}") + private Boolean erpEnabledErpDetTb; + @Value("${erp.useName.ip}") + private String ip; @Autowired private ErpSqlServer erpSqlServer; @Autowired private MatService matService; + @Autowired + private OrderService orderService; + @Autowired + private OrderDetlService orderDetlService; + @Autowired + private SnowflakeIdWorker snowflakeIdWorker; + @Autowired + private DocTypeService docTypeService; + @Autowired + private ApiLogService apiLogService; + /** * 鑾峰彇鍏ュ嚭搴撹鍗曚俊鎭� */ @Scheduled(cron = "${erp.refreshtime}") public void InOrOutOrder() { - if (!erpEnabled) return; - String sqlSelectErpDetTb = "select bill_no as billNo,prd_no as prdNo,iokindid,add_id as addId,qty,prd_mark as prdMark,wh,billdate,status,temp1,temp2,temp3 from erp_det_tb where 1=1"; - String sqlUpDateErpDetTbOne = "update erp_det_tb set status=1 where prd_no="; - String sqlUpDateErpDetTbTwo = "update erp_det_tb set status=2 where prd_no="; + 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,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 "; try { List<ErpDetTb> erpDetTbs = erpSqlServer.select(sqlSelectErpDetTb, ErpDetTb.class); - if (erpDetTbs.size() > 0){ - for (ErpDetTb erpDetTb:erpDetTbs){ + if (erpDetTbs.size() > 0) { + for (ErpDetTb erpDetTb : erpDetTbs) { + Date now = new Date(); Integer status = erpDetTb.getStatus(); - if (status == 0){ + if (status == 0) { + Mat mat = matService.selectByMatnr(erpDetTb.getPrdNo()); + if (Cools.isEmpty(mat)) { + 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()); + if (Cools.isEmpty(order)) { + order = new Order( + String.valueOf(snowflakeIdWorker.nextId()), // 缂栧彿[闈炵┖] + erpDetTb.getBillNo(), // 璁㈠崟缂栧彿 + DateUtils.convert(now), // 鍗曟嵁鏃ユ湡 + null, // 鍗曟嵁绫诲瀷 + null, // 椤圭洰缂栧彿 + null, // + null, // 璋冩嫧椤圭洰缂栧彿 + null, // 鍒濆绁ㄦ嵁鍙� + null, // 绁ㄦ嵁鍙� + null, // 瀹㈡埛缂栧彿 + null, // 瀹㈡埛 + null, // 鑱旂郴鏂瑰紡 + null, // 鎿嶄綔浜哄憳 + null, // 鍚堣閲戦 + null, // 浼樻儬鐜� + null, // 浼樻儬閲戦 + null, // 閿�鍞垨閲囪喘璐圭敤鍚堣 + null, // 瀹炰粯閲戦 + null, // 浠樻绫诲瀷 + null, // 涓氬姟鍛� + null, // 缁撶畻澶╂暟 + null, // 閭垂鏀粯绫诲瀷 + null, // 閭垂 + null, // 浠樻鏃堕棿 + null, // 鍙戣揣鏃堕棿 + null, // 鐗╂祦鍚嶇О + null, // 鐗╂祦鍗曞彿 + 1L, // 璁㈠崟鐘舵�� + 1, // 鐘舵�� + 9999L, // 娣诲姞浜哄憳 + now, // 娣诲姞鏃堕棿 + 9999L, // 淇敼浜哄憳 + now, // 淇敼鏃堕棿 + null // 澶囨敞 + ); + 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)) { + callApiLogSave(erpDetTb, "ERP_DETTB", "璁㈠崟涓绘。娣诲姞澶辫触锛侊紒", false); + continue; + } else { + callApiLogSave(erpDetTb, "ERP_DETTB", "璁㈠崟涓绘。娣诲姞鎴愬姛锛侊紒", true); + } + } + } + Order order1 = orderService.selectByNo(erpDetTb.getBillNo()); + if (!Cools.isEmpty(order1)) { +// OrderDetl orderDetl = orderDetlService.selectItem(order1.getId(), erpDetTb.getBillNo(), erpDetTb.getPrdMark()); + OrderDetl orderDetl = orderDetlService.selectOne(new EntityWrapper<OrderDetl>().eq("order_no",erpDetTb.getBillNo()).eq("matnr",erpDetTb.getPrdNo())); + if (Cools.isEmpty(orderDetl)) { + orderDetl = new OrderDetl(); + orderDetl.setOrderId(order1.getId()); + orderDetl.setOrderNo(erpDetTb.getBillNo()); + orderDetl.setAnfme(erpDetTb.getQty()); + orderDetl.setQty(0.0D); + orderDetl.setMatnr(erpDetTb.getPrdNo()); + orderDetl.setMaktx(mat.getMaktx()); + orderDetl.setBatch(erpDetTb.getPrdMark()); + orderDetl.setSpecs(mat.getSpecs()); + orderDetl.setUnit(mat.getUnit()); + orderDetl.setOrigin(erpDetTb.getItm().toString()); - }else if (status == 1){ + orderDetl.setStatus(1); + orderDetl.setCreateBy(9999L); + orderDetl.setCreateTime(now); + orderDetl.setUpdateBy(9999L); + orderDetl.setUpdateTime(now); + orderDetl.setMemo(erpDetTb.getWh()); + if (orderDetlService.insert(orderDetl)) { + 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 (!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); + } + } + } + } + } else if (status == 1) { + String format = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(now); + HashMap<String, Object> condition = new HashMap<>(); + condition.put("BIL_NO", "'" + erpDetTb.getBillNo() + "'"); + condition.put("PRD_NO", "'" + erpDetTb.getPrdNo() + "'"); + condition.put("ITM", "'" + erpDetTb.getItm() + "'"); + condition.put("ADD_ID", "'" + erpDetTb.getAddId2() + "'"); + condition.put("QTY", "'" + erpDetTb.getQty() + "'"); + condition.put("PRD_MARK", "'" + erpDetTb.getPrdMark() + "'"); + condition.put("WH", "'" + erpDetTb.getWh() + "'"); + condition.put("BIL_DATE", "'" + format + "'"); + condition.put("STATUS", "'" + erpDetTb.getStatus() + "'"); + condition.put("Temp1", "'" + erpDetTb.getTemp1() + "'"); + condition.put("Temp2", "'" + erpDetTb.getTemp2() + "'"); + condition.put("Temp3", "'" + erpDetTb.getTemp3() + "'"); + erpSqlServer.insert(ErpDetTbBak.class, condition); - }else if (status == 2){ +// callApiLogSave(erpDetTb, "ERP_DETTB_BAK", "ERP涓嬪彂璁㈠崟澶囦唤鎴愬姛锛侊紒", true); - }else { + HashMap<String, String> condition2 = new HashMap<>(); + condition2.put("BIL_NO", "'" + erpDetTb.getBillNo() + "'"); + condition2.put("PRD_NO", "'" + erpDetTb.getPrdNo() + "'"); + condition2.put("ITM", "'" + erpDetTb.getItm() + "'"); +// condition2.put("PRD_MARK", "'" + erpDetTb.getPrdMark() + "'"); + erpSqlServer.delete(ErpDetTb.class, condition2); +// callApiLogSave(erpDetTb, "ERP_DETTB", "ERP涓嬪彂璁㈠崟澶囦唤鍚庡垹闄ゆ垚鍔燂紒锛�", true); + + } else { + 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); + } } } } - }catch (Exception e){ - + } catch (Exception e) { + Date date = new Date(); + log.error(date + ": 琛ㄥ悕锛欵RP_DETTB :" + e); } } + + public void callApiLogSave(ErpDetTb erpDetTb, String tableName, String response, Boolean bool) { + apiLogService.save("ERP涓嬪彂璁㈠崟淇℃伅", tableName, "null", ip, + "璁㈠崟鍙凤細" + erpDetTb.getBillNo() + "銆佸搧鍙凤細" + erpDetTb.getPrdNo() + "銆佽揣鍝佺壒寰侊細" + erpDetTb.getPrdMark() + "銆佺姸鎬侊細" + erpDetTb.getStatus$(), + response, bool); + } } -- Gitblit v1.9.1