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