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.check.ErpStockCheckPageReqVO; import cn.iocoder.yudao.module.erp.dal.dataobject.stock.ErpStockCheckDO; import cn.iocoder.yudao.module.erp.dal.dataobject.stock.ErpStockCheckItemDO; import com.baomidou.mybatisplus.core.conditions.update.LambdaUpdateWrapper; import org.apache.ibatis.annotations.Mapper; /** * ERP 库存调拨单 Mapper * * @author 芋道源码 */ @Mapper public interface ErpStockCheckMapper extends BaseMapperX { default PageResult selectPage(ErpStockCheckPageReqVO reqVO) { MPJLambdaWrapperX query = new MPJLambdaWrapperX() .likeIfPresent(ErpStockCheckDO::getNo, reqVO.getNo()) .betweenIfPresent(ErpStockCheckDO::getCheckTime, reqVO.getCheckTime()) .eqIfPresent(ErpStockCheckDO::getStatus, reqVO.getStatus()) .likeIfPresent(ErpStockCheckDO::getRemark, reqVO.getRemark()) .eqIfPresent(ErpStockCheckDO::getCreator, reqVO.getCreator()) .orderByDesc(ErpStockCheckDO::getId); if (reqVO.getWarehouseId() != null || reqVO.getProductId() != null) { query.leftJoin(ErpStockCheckItemDO.class, ErpStockCheckItemDO::getCheckId, ErpStockCheckDO::getId) .eq(reqVO.getWarehouseId() != null, ErpStockCheckItemDO::getWarehouseId, reqVO.getWarehouseId()) .eq(reqVO.getProductId() != null, ErpStockCheckItemDO::getProductId, reqVO.getProductId()) .groupBy(ErpStockCheckDO::getId); // 避免 1 对多查询,产生相同的 1 } return selectJoinPage(reqVO, ErpStockCheckDO.class, query); } default int updateByIdAndStatus(Long id, Integer status, ErpStockCheckDO updateObj) { return update(updateObj, new LambdaUpdateWrapper() .eq(ErpStockCheckDO::getId, id).eq(ErpStockCheckDO::getStatus, status)); } default ErpStockCheckDO selectByNo(String no) { return selectOne(ErpStockCheckDO::getNo, no); } }