自动化立体仓库 - WMS系统
#
luxiaotao1123
2022-12-09 69c4fd1134f598dd2a7d46b5d25a541fd566b275
#
2个文件已修改
38 ■■■■■ 已修改文件
src/main/java/com/zy/asrs/task/handler/WorkLogHandler.java 19 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/main/java/com/zy/common/service/erp/ErpService.java 19 ●●●●● 补丁 | 查看 | 原始文档 | 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){