From 2ab61832f8b85c30958e37215f4daa579e7fa354 Mon Sep 17 00:00:00 2001 From: 杨凯 <398860375@qq.com> Date: 星期三, 18 十月 2023 13:08:28 +0800 Subject: [PATCH] 新增PO --- consum-base/src/main/java/com/consum/base/core/WarehouseCoreService.java | 200 +++++++++++++++++++++++++++++++++++++++++++++++-- 1 files changed, 189 insertions(+), 11 deletions(-) diff --git a/consum-base/src/main/java/com/consum/base/core/WarehouseCoreService.java b/consum-base/src/main/java/com/consum/base/core/WarehouseCoreService.java index 0de0d26..324bf71 100644 --- a/consum-base/src/main/java/com/consum/base/core/WarehouseCoreService.java +++ b/consum-base/src/main/java/com/consum/base/core/WarehouseCoreService.java @@ -1,9 +1,17 @@ package com.consum.base.core; +import com.consum.base.core.tools.SqlParameter; +import com.consum.base.core.util.DateUtil; +import com.consum.model.po.*; +import com.walker.infrastructure.utils.NumberGenerator; +import com.walker.jdbc.service.BaseServiceImpl; import lombok.extern.slf4j.Slf4j; +import org.springframework.beans.BeanUtils; import org.springframework.stereotype.Service; -import org.springframework.transaction.annotation.Transactional; import org.springframework.util.Assert; + +import java.util.ArrayList; +import java.util.List; /** @@ -11,26 +19,37 @@ */ @Service @Slf4j -public class WarehouseCoreService { +public class WarehouseCoreService extends BaseServiceImpl { + + public static void main(String[] args) { + WhGoods goods = new WhGoods(); + goods.setId(1l); + goods.setWarehouseId(111l); + goods.setSupplier("娌冲崡閲戞槑婧�"); + + WhGoods_mapper mapper = new WhGoods_mapper(goods); + System.out.println(mapper.getInsertSql_().getParameters()); + System.out.println(mapper.getInsertSql_().getSql()); + } /** * 缁熶竴鍑哄叆搴� */ - @Transactional(rollbackFor = Exception.class) - public CheckWarehouseResult unifyCheck(CheckWarehouseParam param) { + public List<CheckWarehouseResult> unifyCheck(CheckWarehouseParam param) { // TODO: 10/10/2023 姝ゅ鍔犱簡鍞竴閿侊紝浼氬奖鍝嶆�ц兘锛屾�濊�冩槸鍚︽湁鏇村悎閫傜殑鍔炴硶 try { Assert.notNull(param, "wareHouse param can not null !"); Assert.notNull(param.getWarehouseId(), "wareHouse id can not null"); - CheckWarehouseResult result; + List<CheckWarehouseResult> results; synchronized (param.getWarehouseId()) { if (param.getIsCheckIn()) { - result = checkin(param); + results = new ArrayList<>(); + results.add(checkin(param)); } else { - result = checkout(param); + results = checkout(param); } } - return result; + return results; } catch (Exception e) { log.error(e.getMessage()); throw new RuntimeException(e.getMessage()); @@ -41,14 +60,173 @@ /** * 鍑哄簱 */ - private CheckWarehouseResult checkout(CheckWarehouseParam param) { - return new CheckWarehouseResult(); + private List<CheckWarehouseResult> checkout(CheckWarehouseParam param) { + //鏌ヨ鍑烘寚瀹氫粨搴撱�佹寚瀹氬瀷鍙凤紝鐘舵�佷负姝e父鐨勭殑搴撳瓨鐗╁搧锛屾寜鐓ч噰璐椂闂村�掑彊銆佷环鏍煎�掑彊鎺掑垪 + String sql = "SELECT\n" + + " * \n" + + "FROM\n" + + " WH_GOODS \n" + + "WHERE\n" + + " WAREHOUSE_ID =:WAREHOUSE_ID \n" + + " AND BASE_GOODS_MODELS_ID =:BASE_GOODS_MODELS_ID \n" + + " AND STATES =1 \n" + + " AND WH_COUNT > 0 \n" + + " order by PROCURE_DATE asc PRICE DESC"; + SqlParameter parameter = new SqlParameter(); + parameter.add("WAREHOUSE_ID",param.getWarehouseId()) + .add("BASE_GOODS_MODELS_ID",param.getModelId()); + List<WhGoods> goodsList = select(sql,parameter,new WhGoods()); + List<CheckWarehouseResult> resultList = new ArrayList<>(); + + int shengyu = param.getCount(); + + for (WhGoods goods : goodsList){ + if (shengyu <= 0 ) break; + + //濡傛灉搴撳瓨鏁伴噺澶т簬鍑哄簱鏁伴噺锛岀洿鎺ュ噺搴撳瓨 + if (shengyu <= goods.getWhCount()){ + shengyu = 0; + + CheckWarehouseResult result = new CheckWarehouseResult(); + result.setWhGoods(goods); + result.setInitial_count(goods.getWhCount()); + goods.setWhCount(goods.getWhCount() - param.getCount()); + result.setEnd_count(goods.getWhCount()); + resultList.add(result); + + //濡傛灉鍑忓簱瀛樺悗锛屽簱瀛樻暟涓�0锛屽垯鍙樻洿鐘舵�佷负宸插垹闄� + if (goods.getWhCount() == 0){ + goods.setStates(0); + } + update(goods); + + //濡傛灉鏄皟鎷ㄥ嚭搴� 2:璋冩嫧锛�3锛氭姤搴� + if (param.getOutput_type() == 2 || param.getOutput_type() == 3){ + WhGoods nGoods = new WhGoods(); + BeanUtils.copyProperties(goods,nGoods); + //鍙樻洿鐘舵�佷负璋冩嫧 + nGoods.setStates(param.getOutput_type()); + nGoods.setWhCount(param.getCount()); + nGoods.setId(NumberGenerator.getLongSequenceNumber()); + insert(nGoods); + + CheckWarehouseResult nresult = new CheckWarehouseResult(); + nresult.setWhGoods(nGoods); + nresult.setInitial_count(0); + nresult.setEnd_count(nresult.getEnd_count()); + resultList.add(nresult); + } + + return resultList; + + } + + //濡傛灉搴撳瓨鏁伴噺灏忎簬鍑哄簱鏁伴噺锛屽垯闇�瑕佸嚑涓簱瀛樼墿鍝佷竴璧峰嚭搴撱�� + + CheckWarehouseResult result = new CheckWarehouseResult(); + result.setInitial_count(goods.getWhCount()); + result.setEnd_count(0); + result.setWhGoods(goods); + resultList.add(result); + + shengyu = param.getCount() - goods.getWhCount(); + if (shengyu < 0){ + throw new RuntimeException("鍑哄簱鏃讹紝璁$畻閿欒"); + } + goods.setWhCount(0); + goods.setStates(0); + update(goods); + } + + throw new RuntimeException("鍑哄簱鏃讹紝璁$畻閿欒"); + } + + private BaseWarehouse getWarehouse(long id){ + BaseWarehouse w = get(new BaseWarehouse(),"ID=?",new Object[]{id}); + return w; } /** * 鍏ュ簱 */ - private CheckWarehouseResult checkin(CheckWarehouseParam param) { + private CheckWarehouseResult checkin(CheckWarehouseParam param) throws RuntimeException { + + //濡傛灉鏄噰璐叆搴� + if (param.getFirst_input_type() ==1){ + WhFormProcureModel procureModel = get(new WhFormProcureModel(),"ID=?",new Object[]{param.getFirstInputCode()}); + WhFormProcure procure = get(new WhFormProcure(),"ID=?",new Object[]{procureModel.getWhFormProcureId()}); + + WhGoods goods = new WhGoods(); + goods.setId(NumberGenerator.getLongSequenceNumber()); + goods.setBaseGoodsTemplateId(procureModel.getBaseGoodsTemplateId()); + goods.setGoodsTemplateName(procureModel.getGoodsTemplateName()); + goods.setBaseGoodsModelsId(procureModel.getBaseGoodsModelsId()); + goods.setBaseGoodsModelsName(procureModel.getBaseGoodsModelsName()); + goods.setWhCount(procureModel.getCounts()); + goods.setFirstInputCode(param.getFirstInputCode()); + goods.setFirstInputType(param.getFirst_input_type()); + goods.setFirstInputHisId(NumberGenerator.getLongSequenceNumber()); + goods.setWarehouseId(procure.getWarehouseId()); + goods.setWarehouseName(procure.getWarehouseName()); + goods.setSupplier(procureModel.getSupplier()); + goods.setUnit(procureModel.getUnit()); + goods.setPrice(procureModel.getPrice()); + goods.setProcureDate(procure.getIncomeTime()); + goods.setBackDate(procure.getIncomeTime()); + goods.setStates(1); + insert(goods); + + CheckWarehouseResult result = new CheckWarehouseResult(); + result.setWhGoods(goods); + result.setInitial_count(0); + result.setEnd_count(goods.getWhCount()); + return result; + //闆舵槦鍏ュ簱 + } else if (param.getFirst_input_type() ==2){ + + return null; + + } + + String sql = "SELECT\n" + + " * \n" + + "FROM\n" + + " WH_GOODS \n" + + "WHERE\n" + + " WAREHOUSE_ID =:WAREHOUSE_ID \n" + + " AND FIRST_INPUT_CODE =:FIRST_INPUT_CODE \n" + + " AND BASE_GOODS_MODELS_ID =:BASE_GOODS_MODELS_ID" + + " order by PROCURE_DATE desc PRICE asc"; + SqlParameter parameter = new SqlParameter(); + parameter.add("WAREHOUSE_ID",param.getWarehouseId()) + .add("FIRST_INPUT_CODE",param.getFirstInputCode()) + .add("BASE_GOODS_MODELS_ID",param.getModelId()); + + List<WhGoods> goodsList = select(sql,parameter,new WhGoods()); + + if (goodsList == null || goodsList.size() == 0){ + new RuntimeException("鏌ヤ笉鍒板巻鍙插簱瀛�"); + return null; + } + + for (WhGoods goods : goodsList){ + CheckWarehouseResult result = new CheckWarehouseResult(); + result.setWhGoods(goods); + result.setInitial_count(goods.getWhCount()); + result.setEnd_count(goods.getWhCount() + param.getCount()); + + WhGoods newGoods = new WhGoods(); + newGoods.setId(goods.getId()); + newGoods.setWhCount(result.getEnd_count()); + newGoods.setStates(1); + newGoods.setBackDate(DateUtil.getCurrentDateFor14()); + this.update(newGoods); + + return result; + } + + + return new CheckWarehouseResult(); } -- Gitblit v1.9.1