自动化立体仓库 - WMS系统
zhou zhou
2025-12-19 b0d80cc56a883a6fac242623e778a3ae20c71b79
#库存预留
5个文件已修改
182 ■■■■ 已修改文件
src/main/java/com/zy/asrs/controller/OrderPakoutController.java 7 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/main/java/com/zy/asrs/entity/InventoryReserve.java 42 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/main/java/com/zy/asrs/entity/InventoryReserveLog.java 45 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/main/java/com/zy/asrs/task/handler/InventoryReserveExpireHandler.java 85 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/main/webapp/static/js/inventoryReserveLog/inventoryReserveLog.js 3 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/main/java/com/zy/asrs/controller/OrderPakoutController.java
@@ -492,6 +492,13 @@
            reserve.setCreateBy(userId);
            reserve.setUpdateTime(now);
            reserve.setUpdateBy(userId);
            reserve.setBrand(detl.getBrand());
            reserve.setStandby1(detl.getStandby1());
            reserve.setStandby2(detl.getStandby2());
            reserve.setStandby3(detl.getStandby3());
            reserve.setBoxType1(detl.getBoxType1());
            reserve.setBoxType2(detl.getBoxType2());
            reserve.setBoxType3(detl.getBoxType3());
            inventoryReserveService.insert(reserve);
        }
        return R.ok("预留成功,共创建 " + orderDetls.size() + " 条预留记录");
src/main/java/com/zy/asrs/entity/InventoryReserve.java
@@ -111,6 +111,48 @@
    @TableField("update_by")
    private Long updateBy;
    @ApiModelProperty(value = "品牌")
    private String brand;
    /**
     * 备用1
     */
    @ApiModelProperty(value = "备用1")
    private String standby1 = "";
    /**
     * 备用2
     */
    @ApiModelProperty(value = "备用2")
    private String standby2 = "";
    /**
     * 备用3
     */
    @ApiModelProperty(value = "备用3")
    private String standby3 = "";
    /**
     * 备用1
     */
    @ApiModelProperty(value = "备用1")
    @TableField("box_type1")
    private String boxType1 = "1";
    /**
     * 备用2
     */
    @ApiModelProperty(value = "备用2")
    @TableField("box_type2")
    private String boxType2 = "1";
    /**
     * 备用3
     */
    @ApiModelProperty(value = "备用3")
    @TableField("box_type3")
    private String boxType3 = "1";
    public InventoryReserve() {}
    public InventoryReserve(String matnr,String maktx,String orderNo,String batch,BigDecimal quantity,Date expiceTime,Long deptId,Date createTime,Long createBy,Date updateTime,Long updateBy) {
src/main/java/com/zy/asrs/entity/InventoryReserveLog.java
@@ -111,6 +111,51 @@
    @TableField("update_by")
    private Long updateBy;
    @ApiModelProperty(value = "品牌")
    private String brand;
    /**
     * 备用1
     */
    @ApiModelProperty(value = "备用1")
    private String standby1 = "";
    /**
     * 备用2
     */
    @ApiModelProperty(value = "备用2")
    private String standby2 = "";
    /**
     * 备用3
     */
    @ApiModelProperty(value = "备用3")
    private String standby3 = "";
    /**
     * 备用1
     */
    @ApiModelProperty(value = "备用1")
    @TableField("box_type1")
    private String boxType1 = "1";
    /**
     * 备用2
     */
    @ApiModelProperty(value = "备用2")
    @TableField("box_type2")
    private String boxType2 = "1";
    /**
     * 备用3
     */
    @ApiModelProperty(value = "备用3")
    @TableField("box_type3")
    private String boxType3 = "1";
    @ApiModelProperty(value = "备注")
    private String memo;
    public InventoryReserveLog() {}
    public InventoryReserveLog(String matnr,String maktx,String orderNo,String batch,BigDecimal quantity,Date expiceTime,Long deptId,Date createTime,Long createBy,Date updateTime,Long updateBy) {
src/main/java/com/zy/asrs/task/handler/InventoryReserveExpireHandler.java
@@ -1,13 +1,17 @@
package com.zy.asrs.task.handler;
import com.baomidou.mybatisplus.mapper.EntityWrapper;
import com.core.common.Cools;
import com.zy.asrs.entity.InventoryReserve;
import com.zy.asrs.entity.InventoryReserveLog;
import com.zy.asrs.entity.OrderPakout;
import com.zy.asrs.service.InventoryReserveLogService;
import com.zy.asrs.service.InventoryReserveService;
import com.zy.asrs.service.OrderPakoutService;
import com.zy.asrs.task.AbstractHandler;
import com.zy.asrs.task.core.ReturnT;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.BeanUtils;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;
@@ -18,6 +22,9 @@
/**
 * 预留库存过期处理器
 * 将过期的预留库存转移到日志表
 * 转历史条件:
 * 1. 过期时间不为空且已过期
 * 2. 订单号不为空且订单状态为作业中(1)或已完成(2)
 */
@Slf4j
@Service
@@ -29,55 +36,69 @@
    @Autowired
    private InventoryReserveLogService inventoryReserveLogService;
    @Autowired
    private OrderPakoutService orderPakoutService;
    @Transactional(rollbackFor = Exception.class)
    public ReturnT<String> start() {
        // 查询过期的预留库存(过期时间不为空且小于当前时间)
        Date now = new Date();
        List<InventoryReserve> expiredList = inventoryReserveService.selectList(
                new EntityWrapper<InventoryReserve>()
                        .isNotNull("expire_time")
                        .lt("expire_time", now));
        if (expiredList.isEmpty()) {
        // 查询所有预留库存记录
        List<InventoryReserve> allReserves = inventoryReserveService.selectList(new EntityWrapper<>());
        if (allReserves.isEmpty()) {
            return SUCCESS;
        }
        log.info("发现 {} 条过期的预留库存记录", expiredList.size());
        for (InventoryReserve reserve : expiredList) {
        int processedCount = 0;
        for (InventoryReserve reserve : allReserves) {
            try {
                // 转移到日志表
                InventoryReserveLog logRecord = getInventoryReserveLog(reserve);
                boolean shouldArchive = false;
                String archiveReason = null;
                inventoryReserveLogService.insert(logRecord);
                // 条件1:过期时间不为空且已过期
                if (reserve.getExpireTime() != null && reserve.getExpireTime().before(now)) {
                    shouldArchive = true;
                    archiveReason = "已过期";
                }
                // 删除原记录
                inventoryReserveService.deleteById(reserve.getId());
                // 条件2:订单号不为空且订单状态为作业中或已完成
                if (!shouldArchive && !Cools.isEmpty(reserve.getOrderNo())) {
                    OrderPakout order = orderPakoutService.selectOne(
                            new EntityWrapper<OrderPakout>().eq("order_no", reserve.getOrderNo()));
                    if (null != order) {
                        if (order.getSettle() != 1) {
                            shouldArchive = true;
                            archiveReason =  "订单不为待处理状态";
                        }
                    }
                }
                log.info("预留库存过期处理完成: id={}, matnr={}, batch={}",
                        reserve.getId(), reserve.getMatnr(), reserve.getBatch());
                if (shouldArchive) {
                    // 转移到日志表
                    InventoryReserveLog logRecord = new InventoryReserveLog();
                    BeanUtils.copyProperties(reserve, logRecord);
                    logRecord.setMemo(archiveReason);
                    inventoryReserveLogService.insert(logRecord);
                    // 删除原记录
                    inventoryReserveService.deleteById(reserve.getId());
                    log.info("预留库存转历史完成: id={}, matnr={}, batch={}, 原因={}",
                            reserve.getId(), reserve.getMatnr(), reserve.getBatch(), archiveReason);
                    processedCount++;
                }
            } catch (Exception e) {
                log.error("预留库存过期处理失败: id={}, error={}", reserve.getId(), e.getMessage());
                log.error("预留库存转历史失败: id={}, error={}", reserve.getId(), e.getMessage());
            }
        }
        return SUCCESS;
    }
        if (processedCount > 0) {
            log.info("本次共处理 {} 条预留库存转历史记录", processedCount);
        }
    private static InventoryReserveLog getInventoryReserveLog(InventoryReserve reserve) {
        InventoryReserveLog logRecord = new InventoryReserveLog();
        logRecord.setMatnr(reserve.getMatnr());
        logRecord.setMaktx(reserve.getMaktx());
        logRecord.setOrderNo(reserve.getOrderNo());
        logRecord.setBatch(reserve.getBatch());
        logRecord.setQuantity(reserve.getQuantity());
        logRecord.setExpireTime(reserve.getExpireTime());
        logRecord.setDeptId(reserve.getDeptId());
        logRecord.setCreateTime(reserve.getCreateTime());
        logRecord.setCreateBy(reserve.getCreateBy());
        logRecord.setUpdateTime(new Date());
        return logRecord;
        return SUCCESS;
    }
}
src/main/webapp/static/js/inventoryReserveLog/inventoryReserveLog.js
@@ -26,7 +26,8 @@
            { field: 'quantity', align: 'center', title: '数量', width: 100 },
            { field: 'expiceTime$', align: 'center', title: '过期时间', width: 180 },
            { field: 'createTime$', align: 'center', title: '原创建时间', width: 180 },
            { field: 'updateTime$', align: 'center', title: '转移时间', width: 180 }
            { field: 'updateTime$', align: 'center', title: '转移时间', width: 180 },
            { field: 'memo', align: 'center', title: '过期原因', width: 180 }
        ]],
        request: {
            pageName: 'curr',