package cn.iocoder.yudao.module.erp.dal.mysql.stock; import cn.iocoder.yudao.framework.common.pojo.PageResult; import cn.iocoder.yudao.framework.mybatis.core.mapper.BaseMapperX; import cn.iocoder.yudao.framework.mybatis.core.query.MPJLambdaWrapperX; import cn.iocoder.yudao.module.erp.controller.admin.stock.vo.move.ErpStockMovePageReqVO; import cn.iocoder.yudao.module.erp.dal.dataobject.stock.ErpStockMoveDO; import cn.iocoder.yudao.module.erp.dal.dataobject.stock.ErpStockMoveItemDO; import com.baomidou.mybatisplus.core.conditions.update.LambdaUpdateWrapper; import org.apache.ibatis.annotations.Mapper; /** * ERP 库存调拨单 Mapper * * @author 芋道源码 */ @Mapper public interface ErpStockMoveMapper extends BaseMapperX { default PageResult selectPage(ErpStockMovePageReqVO reqVO) { MPJLambdaWrapperX query = new MPJLambdaWrapperX() .likeIfPresent(ErpStockMoveDO::getNo, reqVO.getNo()) .betweenIfPresent(ErpStockMoveDO::getMoveTime, reqVO.getMoveTime()) .eqIfPresent(ErpStockMoveDO::getStatus, reqVO.getStatus()) .likeIfPresent(ErpStockMoveDO::getRemark, reqVO.getRemark()) .eqIfPresent(ErpStockMoveDO::getCreator, reqVO.getCreator()) .orderByDesc(ErpStockMoveDO::getId); if (reqVO.getFromWarehouseId() != null || reqVO.getProductId() != null) { query.leftJoin(ErpStockMoveItemDO.class, ErpStockMoveItemDO::getMoveId, ErpStockMoveDO::getId) .eq(reqVO.getFromWarehouseId() != null, ErpStockMoveItemDO::getFromWarehouseId, reqVO.getFromWarehouseId()) .eq(reqVO.getProductId() != null, ErpStockMoveItemDO::getProductId, reqVO.getProductId()) .groupBy(ErpStockMoveDO::getId); // 避免 1 对多查询,产生相同的 1 } return selectJoinPage(reqVO, ErpStockMoveDO.class, query); } default int updateByIdAndStatus(Long id, Integer status, ErpStockMoveDO updateObj) { return update(updateObj, new LambdaUpdateWrapper() .eq(ErpStockMoveDO::getId, id).eq(ErpStockMoveDO::getStatus, status)); } default ErpStockMoveDO selectByNo(String no) { return selectOne(ErpStockMoveDO::getNo, no); } }