src/main/java/com/zy/asrs/task/handler/WorkLogHandler.java | ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史 | |
src/main/java/com/zy/common/service/erp/ErpService.java | ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史 |
src/main/java/com/zy/asrs/task/handler/WorkLogHandler.java
@@ -9,6 +9,8 @@ import com.zy.asrs.task.AbstractHandler; import com.zy.asrs.task.core.ReturnT; import com.zy.common.model.OrderDto; import com.zy.common.service.erp.ErpService; import com.zy.common.service.erp.entity.Goods; import com.zy.common.web.BaseController; import lombok.extern.slf4j.Slf4j; import org.springframework.beans.factory.annotation.Autowired; @@ -41,6 +43,8 @@ private WaitPakinLogService waitPakinLogService; @Autowired private OrderService orderService; @Autowired private ErpService erpService; // update asr_wrk_mast set inv_wh = 'Y', ove_mk = 'Y' where wrk_no = @Transactional @@ -62,6 +66,21 @@ // 入库 -------------------------------------------------------------------------------- if (wrkMast.getWrkSts() == 10) { // 搜索对应入库条码在erp数据库中的状态 List<WrkDetl> wrkDetls0 = wrkDetlService.selectByWrkNo(wrkMast.getWrkNo()); for (WrkDetl wrkDetl : wrkDetls0) { Goods goods = erpService.selectGoodsOne(wrkDetl.getMatnr()); if (!Cools.isEmpty(goods)) { if (!erpService.updateStateAndLocForGoods(goods.getBarCode(), 3, wrkMast.getLocNo())) { log.error("{}条码在erp数据库中更新失败!", goods.getBarCode()); } } else { log.error("{}条码不在erp数据库中!", wrkDetl.getMatnr()); } } // 全板入库 if (wrkMast.getIoType() == 1) { // 入库通知单 src/main/java/com/zy/common/service/erp/ErpService.java
@@ -38,6 +38,16 @@ return erpSqlServer.select(sql, Goods.class); } public Goods selectGoodsOne(String barCode) { String sql = "select top 1 * from Goods where BarCode = '" + barCode + "'"; List<Goods> select = erpSqlServer.select(sql, Goods.class); if (Cools.isEmpty(select)) { return null; } else { return select.get(0); } } public List<VoucherDto> selectOrder(Integer state) { List<VoucherDto> list = new ArrayList<>(); List<Voucher> voucherList = this.selectVoucher(state); @@ -85,6 +95,15 @@ } /** * 修改 Goods 表 state, location */ public boolean updateStateAndLocForGoods(String barcode, Integer state, String loc){ String sql = "update Goods set State = ''{1}'', LastUpdatedDate = ''{2}'', Location = ''{3}'' where BarCode = ''{0}''"; sql = MessageFormat.format(sql, barcode, state, DateUtils.convert(new Date()), loc); return erpSqlServer.update(sql) > 0; } /** * 修改 Voucher 表 state */ public boolean updateStateForVoucher(String voucherID, Integer state){