|  |  |  | 
|---|
|  |  |  | private Boolean erpEnabled; | 
|---|
|  |  |  | @Value("${erp.useName.ip}") | 
|---|
|  |  |  | private String ip; | 
|---|
|  |  |  | @Value("${erp.enabledErpPrdt}") | 
|---|
|  |  |  | private Boolean enabledErpPrdt; | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private ApiLogService apiLogService; | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | 
|---|
|  |  |  | private MatService matService; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 获取商品信息表资料  年前 | 
|---|
|  |  |  | * 获取商品信息表资料 | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | @Scheduled(cron = "${erp.refreshtime}") | 
|---|
|  |  |  | public void obtainPedt() { | 
|---|
|  |  |  | if (!erpEnabled) return; | 
|---|
|  |  |  | String sqlSelectPrdt = "select PRD_NO as prdNo,NAME as name,UT as ut,SPC as spc from PRDT where 1=1"; | 
|---|
|  |  |  | String sqlUpDatePrdtOne = "update PRDT set STATUS=1 where PRD_NO="; | 
|---|
|  |  |  | String sqlUpDatePrdtTwo = "update PRDT set STATUS=2 where PRD_NO="; | 
|---|
|  |  |  | if (!enabledErpPrdt) return; | 
|---|
|  |  |  | String sqlSelectPrdt = "select prd_no as prdNo,name,ut,spc,status,type,temp1,temp2,temp3 from ERP_PRDT where 1=1 and temp1 is null"; | 
|---|
|  |  |  | String sqlUpDatePrdtOne = "update ERP_PRDT set status=1 where prd_no="; | 
|---|
|  |  |  | String sqlUpDatePrdtTwo = "update ERP_PRDT set status=2 "; | 
|---|
|  |  |  | try { | 
|---|
|  |  |  | Tag tag = tagService.selectByName("全部", 1); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | 
|---|
|  |  |  | if (prdts.size() > 0) { | 
|---|
|  |  |  | for (Prdt prdt : prdts) { | 
|---|
|  |  |  | Date date = new Date(); | 
|---|
|  |  |  | Integer type = prdt.getType(); | 
|---|
|  |  |  | Mat mat = matService.selectByMatnr(prdt.getPrdNo()); | 
|---|
|  |  |  | if (Cools.isEmpty(mat)) { | 
|---|
|  |  |  | Mat matNew = new Mat(); | 
|---|
|  |  |  | matNew.setTagId(tag.getId()); | 
|---|
|  |  |  | matNew.setMatnr(prdt.getPrdNo()); | 
|---|
|  |  |  | matNew.setMaktx(prdt.getName()); | 
|---|
|  |  |  | matNew.setUnit(prdt.getUt()); | 
|---|
|  |  |  | matNew.setSpecs(prdt.getSpc()); | 
|---|
|  |  |  | matNew.setCreateBy(9999L);//9999表示erp下发 | 
|---|
|  |  |  | matNew.setCreateTime(date); | 
|---|
|  |  |  | matNew.setUpdateBy(9999L);//9999表示erp下发 | 
|---|
|  |  |  | matNew.setUpdateTime(date); | 
|---|
|  |  |  | if (matService.insert(matNew)) { | 
|---|
|  |  |  | //                                erpSqlServer.update(sqlUpDatePrdtOne + "'" + prdt.getPrdNo() + "'"); | 
|---|
|  |  |  | callApiLogSave(prdt, "PRDT", "接收ERP下发商品信息成功!添加商品信息成功!", true); | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | //                                erpSqlServer.update(sqlUpDatePrdtTwo + "'" + prdt.getPrdNo() + "'"); | 
|---|
|  |  |  | callApiLogSave(prdt, "PRDT", "接收ERP下发商品信息失败!!!添加商品信息失败!!!", false); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | //                            erpSqlServer.update(sqlUpDatePrdtTwo + "'" + prdt.getPrdNo() + "'"); | 
|---|
|  |  |  | callApiLogSave(prdt, "PRDT", "接收ERP下发商品信息失败!!!商品已存在!!!", false); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | /*Date date = new Date(); | 
|---|
|  |  |  | if (prdt.getStatus() == 0) { | 
|---|
|  |  |  | Integer type = prdt.getType(); | 
|---|
|  |  |  | if (type == 1) { | 
|---|
|  |  |  | 
|---|
|  |  |  | matNew.setUpdateTime(date); | 
|---|
|  |  |  | if (matService.insert(matNew)) { | 
|---|
|  |  |  | erpSqlServer.update(sqlUpDatePrdtOne + "'" + prdt.getPrdNo() + "'"); | 
|---|
|  |  |  | callApiLogSave(prdt, "PRDT", "接收ERP下发商品信息成功!添加商品信息成功!", true); | 
|---|
|  |  |  | callApiLogSave(prdt, "ERP_PRDT", "接收ERP下发商品信息成功!添加商品信息成功!", true); | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | erpSqlServer.update(sqlUpDatePrdtTwo + "'" + prdt.getPrdNo() + "'"); | 
|---|
|  |  |  | callApiLogSave(prdt, "PRDT", "接收ERP下发商品信息失败!!!添加商品信息失败!!!", false); | 
|---|
|  |  |  | if (Cools.isEmpty(prdt.getTemp1())){ | 
|---|
|  |  |  | erpSqlServer.update(sqlUpDatePrdtTwo +",Temp1='添加ERP下发商品信息失败!!!状态异常!!!'" | 
|---|
|  |  |  | + "where 1=1 " +" and PRD_NO=" + "'" + prdt.getPrdNo() + "'"); | 
|---|
|  |  |  | callApiLogSave(prdt, "ERP_PRDT", "添加ERP下发商品信息失败!!!状态异常!!!", false); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | erpSqlServer.update(sqlUpDatePrdtTwo + "'" + prdt.getPrdNo() + "'"); | 
|---|
|  |  |  | callApiLogSave(prdt, "PRDT", "接收ERP下发商品信息失败!!!商品已存在!!!", false); | 
|---|
|  |  |  | if (Cools.isEmpty(prdt.getTemp1())){ | 
|---|
|  |  |  | erpSqlServer.update(sqlUpDatePrdtTwo +",Temp1='接收ERP下发商品信息失败!!!商品已存在!!!'" | 
|---|
|  |  |  | + "where 1=1 " +" and PRD_NO=" + "'" + prdt.getPrdNo() + "'"); | 
|---|
|  |  |  | callApiLogSave(prdt, "ERP_PRDT", "接收ERP下发商品信息失败!!!商品已存在!!!", false); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } else if (type == 2) { | 
|---|
|  |  |  | Mat mat = matService.selectByMatnr(prdt.getPrdNo()); | 
|---|
|  |  |  | 
|---|
|  |  |  | mat.setSpecs(prdt.getSpc()); | 
|---|
|  |  |  | if (matService.updateById(mat)) { | 
|---|
|  |  |  | erpSqlServer.update(sqlUpDatePrdtOne + "'" + prdt.getPrdNo() + "'"); | 
|---|
|  |  |  | callApiLogSave(prdt, "PRDT", "接收ERP下发商品信息成功!修改商品信息成功!", true); | 
|---|
|  |  |  | callApiLogSave(prdt, "ERP_PRDT", "接收ERP下发商品信息成功!修改商品信息成功!", true); | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | erpSqlServer.update(sqlUpDatePrdtTwo + "'" + prdt.getPrdNo() + "'"); | 
|---|
|  |  |  | callApiLogSave(prdt, "PRDT", "接收ERP下发商品信息失败!!!修改商品信息失败!!!", false); | 
|---|
|  |  |  | if (Cools.isEmpty(prdt.getTemp1())){ | 
|---|
|  |  |  | erpSqlServer.update(sqlUpDatePrdtTwo +",Temp1='接收ERP下发商品信息失败!!!修改商品信息失败!!!'" | 
|---|
|  |  |  | + "where 1=1 " +" and PRD_NO=" + "'" + prdt.getPrdNo() + "'"); | 
|---|
|  |  |  | callApiLogSave(prdt, "ERP_PRDT", "接收ERP下发商品信息失败!!!修改商品信息失败!!!", false); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } else if (type == 3) { | 
|---|
|  |  |  | 
|---|
|  |  |  | if (!Cools.isEmpty(mat)) { | 
|---|
|  |  |  | if (matService.deleteById(mat.getId())) { | 
|---|
|  |  |  | erpSqlServer.update(sqlUpDatePrdtOne + "'" + prdt.getPrdNo() + "'"); | 
|---|
|  |  |  | callApiLogSave(prdt, "PRDT", "接收ERP下发商品信息成功!删除商品信息成功!", true); | 
|---|
|  |  |  | callApiLogSave(prdt, "ERP_PRDT", "接收ERP下发商品信息成功!删除商品信息成功!", true); | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | erpSqlServer.update(sqlUpDatePrdtTwo + "'" + prdt.getPrdNo() + "'"); | 
|---|
|  |  |  | callApiLogSave(prdt, "PRDT", "接收ERP下发商品信息成功!删除商品信息失败!", false); | 
|---|
|  |  |  | if (Cools.isEmpty(prdt.getTemp1())){ | 
|---|
|  |  |  | erpSqlServer.update(sqlUpDatePrdtTwo +",Temp1='接收ERP下发商品信息成功!删除商品信息失败!'" | 
|---|
|  |  |  | + "where 1=1 " +" and PRD_NO=" + "'" + prdt.getPrdNo() + "'"); | 
|---|
|  |  |  | callApiLogSave(prdt, "ERP_PRDT", "接收ERP下发商品信息成功!删除商品信息失败!", false); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | callApiLogSave(prdt, "PRDT", "商品信息出现异常资料未处理!", false); | 
|---|
|  |  |  | if (Cools.isEmpty(prdt.getTemp1()) && Cools.isEmpty(prdt.getTemp2()) && Cools.isEmpty(prdt.getTemp3())){ | 
|---|
|  |  |  | erpSqlServer.update(sqlUpDatePrdtTwo +",Temp1='接收ERP下发商品信息失败!!!type状态异常!!!'" | 
|---|
|  |  |  | + "where 1=1 " +" and PRD_NO=" + "'" + prdt.getPrdNo() + "'"); | 
|---|
|  |  |  | callApiLogSave(prdt, "ERP_PRDT", "商品信息出现异常资料未处理!", false); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }*/ /*else if (prdt.getStatus() == 1) { | 
|---|
|  |  |  | } else if (prdt.getStatus() == 1) { | 
|---|
|  |  |  | HashMap<String, Object> condition = new HashMap<>(); | 
|---|
|  |  |  | condition.put("PRD_NO", "'" + prdt.getPrdNo() + "'"); | 
|---|
|  |  |  | condition.put("NAME", "'" + prdt.getName() + "'"); | 
|---|
|  |  |  | condition.put("UT", "'" + prdt.getUt() + "'"); | 
|---|
|  |  |  | condition.put("SPC", "'" + prdt.getSpc() + "'"); | 
|---|
|  |  |  | condition.put("TYPE", "'" + prdt.getType() + "'"); | 
|---|
|  |  |  | condition.put("STATUS", "'" + prdt.getStatus() + "'"); | 
|---|
|  |  |  | condition.put("prd_no", "'" + prdt.getPrdNo() + "'"); | 
|---|
|  |  |  | condition.put("name", "'" + prdt.getName() + "'"); | 
|---|
|  |  |  | condition.put("ut", "'" + prdt.getUt() + "'"); | 
|---|
|  |  |  | condition.put("spc", "'" + prdt.getSpc() + "'"); | 
|---|
|  |  |  | condition.put("type", "'" + prdt.getType() + "'"); | 
|---|
|  |  |  | condition.put("status", "'" + prdt.getStatus() + "'"); | 
|---|
|  |  |  | erpSqlServer.insert(PrdtBak.class, condition); | 
|---|
|  |  |  | //                        callApiLogSave(prdt, "erp_prdt_bak", "ERP下发商品信息备份成功!", true); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | 
|---|
|  |  |  | erpSqlServer.delete(Prdt.class, condition2); | 
|---|
|  |  |  | //                        callApiLogSave(prdt, "erp_prdt", "ERP下发商品信息备份后删除成功!", true); | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | callApiLogSave(prdt, "PRDT", "商品信息出现异常资料未处理!", false); | 
|---|
|  |  |  | }*/ | 
|---|
|  |  |  | if (Cools.isEmpty(prdt.getTemp1()) && Cools.isEmpty(prdt.getTemp2()) && Cools.isEmpty(prdt.getTemp3())){ | 
|---|
|  |  |  | erpSqlServer.update(sqlUpDatePrdtTwo +",Temp1='接收ERP下发商品信息失败!!!status状态异常!!!'" | 
|---|
|  |  |  | + "where 1=1 " +" and PRD_NO=" + "'" + prdt.getPrdNo() + "'"); | 
|---|
|  |  |  | callApiLogSave(prdt, "ERP_PRDT", "商品信息出现异常资料未处理!", false); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } catch (Exception e) { | 
|---|
|  |  |  | Date date = new Date(); | 
|---|
|  |  |  | log.error(date + ": 表名:PRDT :" + e); | 
|---|
|  |  |  | log.error(date + ": 表名:ERP_PRDT :" + e); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|