package com.consum.base.service; import com.consum.base.pojo.LWhFormProcureParam; import com.consum.model.po.LWhFormProcure; import com.walker.db.page.GenericPager; import com.walker.infrastructure.utils.StringUtils; import com.walker.jdbc.service.BaseServiceImpl; import org.springframework.stereotype.Service; import java.util.HashMap; /** * @ClassName lWhFormProcureService * @Author cy * @Date 2023/10/24 * @Description 采购单 * @Version 1.0 **/ @Service public class LWhFormProcureService extends BaseServiceImpl { private static String QUERY_FORM_PROCURE_LIST = "SELECT * FROM L_WH_FORM_PROCURE WHERE 1 = 1"; public GenericPager queryFormProcureList(LWhFormProcureParam param) { HashMap paramts = new HashMap<>(); StringBuilder sql = new StringBuilder(QUERY_FORM_PROCURE_LIST); //入库单号 if (!StringUtils.isEmpty(param.getBusinessFormCode())) { sql.append(" and BUSINESS_FORM_CODE like :businessFormCode "); paramts.put("businessFormCode", StringUtils.CHAR_PERCENT + param.getBusinessFormCode() + StringUtils.CHAR_PERCENT); } if (param.getAgencyId() != null){ sql.append(" and AGENCY_ID like :agencyId "); paramts.put("agencyId", param.getAgencyId() + StringUtils.CHAR_PERCENT); } //创建人 if (!StringUtils.isEmpty(param.getBuyerName())) { sql.append(" and buyer_Name =:buyerName "); paramts.put("buyerName", param.getBuyerName()); } //状态 if (param.getStates() != null) { sql.append(" and status =:status "); paramts.put("status", param.getStates()); } //入库时间 if (param.getIncomeTimeStart() != null) { sql.append(" and INCOME_TIME >=:incomeTimeStart "); paramts.put("incomeTimeStart", param.getIncomeTimeStart() * 1000000); } if (param.getIncomeTimeEnd() != null) { sql.append(" and INCOME_TIME <:incomeTimeEnd "); paramts.put("incomeTimeEnd", param.getIncomeTimeEnd() * 1000000 + 240000); } //物品名称 if (!StringUtils.isEmpty(param.getGoodsTemplateName())) { sql.append(" AND id IN (SELECT BUSINESS_ID FROM L_WH_PROCURE_MODEL procureModel LEFT JOIN BASE_GOODS_MODELS baseModel ON procureModel.BASE_GOODS_MODELS_ID=baseModel.ID LEFT JOIN BASE_GOODS_TEMPLATE baseTemp ON baseModel.GOODS_TEMPLATES_ID=baseTemp.id WHERE procureModel.BUSINESS_TYPE=1 AND baseTemp.GOODS_NAME LIKE :goodsTemplateName)"); paramts.put("goodsTemplateName", StringUtils.CHAR_PERCENT + param.getGoodsTemplateName() + StringUtils.CHAR_PERCENT); } sql.append(" ORDER BY PROCURE_TIME DESC"); GenericPager genericPager = selectSplit(sql.toString(), paramts, new LWhFormProcure()); return genericPager; } }