From 6bbac4845106ca8648900b1d9af758c84275ffee Mon Sep 17 00:00:00 2001 From: lishenao <3065849776@qq.com> Date: 星期五, 04 七月 2025 18:09:49 +0800 Subject: [PATCH] 批量添加入库的方法 --- src/main/java/com/ruoyi/inventory/service/impl/StockManagementServiceImpl.java | 74 ++++++++++++++++++++++++++++++++++++ 1 files changed, 73 insertions(+), 1 deletions(-) diff --git a/src/main/java/com/ruoyi/inventory/service/impl/StockManagementServiceImpl.java b/src/main/java/com/ruoyi/inventory/service/impl/StockManagementServiceImpl.java index 18a48dd..8f4c462 100644 --- a/src/main/java/com/ruoyi/inventory/service/impl/StockManagementServiceImpl.java +++ b/src/main/java/com/ruoyi/inventory/service/impl/StockManagementServiceImpl.java @@ -1,25 +1,42 @@ package com.ruoyi.inventory.service.impl; +import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; import com.baomidou.mybatisplus.core.metadata.IPage; import com.baomidou.mybatisplus.extension.plugins.pagination.Page; import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; -import com.ruoyi.basic.excel.SupplierManageExcelDto; +import com.ruoyi.basic.mapper.SupplierManageMapper; +import com.ruoyi.basic.pojo.SupplierManage; import com.ruoyi.common.utils.poi.ExcelUtil; import com.ruoyi.inventory.dto.StockManagementDto; import com.ruoyi.inventory.excel.StockManagementExcelDto; import com.ruoyi.inventory.mapper.StockManagementMapper; +import com.ruoyi.inventory.mapper.StockOutMapper; import com.ruoyi.inventory.pojo.StockManagement; +import com.ruoyi.inventory.pojo.StockOut; import com.ruoyi.inventory.service.StockManagementService; +import com.ruoyi.purchase.dto.ProductRecordDto; +import com.ruoyi.purchase.mapper.ProductRecordMapper; +import com.ruoyi.purchase.pojo.ProductRecord; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; +import org.springframework.transaction.annotation.Transactional; import javax.servlet.http.HttpServletResponse; +import java.util.Date; import java.util.List; @Service public class StockManagementServiceImpl extends ServiceImpl<StockManagementMapper,StockManagement> implements StockManagementService { @Autowired private StockManagementMapper stockManagementMapper; + @Autowired + private StockOutMapper stockOutMapper; + @Autowired + private ProductRecordMapper productRecordMapper; + @Autowired + private SupplierManageMapper supplierManageMapper; + + @Override public int updateStockManagement(StockManagement stockManagement) { @@ -43,4 +60,59 @@ ExcelUtil<StockManagementExcelDto> util = new ExcelUtil<StockManagementExcelDto>(StockManagementExcelDto.class); util.exportExcel(response, stockManageList, "搴撳瓨瀵煎嚭"); } + + @Override + @Transactional(rollbackFor = Exception.class) + public int stockout(StockManagement stockManagement) { +// 鍦ㄥ墠绔叾瀹炲氨绌夸簡3涓暟锛屾暟閲忥紝鍑哄簱浜猴紝鏃堕棿锛屽彧闇�瑕佽繘琛屽垽鏂紝搴撳瓨鏁伴噺鏄惁瓒冲鍗冲彲,鏈変笁绉嶆儏鍐� + StockOut stockOut = new StockOut(); + LambdaQueryWrapper<StockManagement> queryWrapper = new LambdaQueryWrapper<>(); + queryWrapper.eq(StockManagement::getId, stockManagement.getId()); + StockManagement stockManagement1 = stockManagementMapper.selectOne(queryWrapper); + if (stockManagement1.getStockQuantity() < stockManagement.getStockQuantity()) { + throw new RuntimeException("搴撳瓨鏁伴噺涓嶈冻"); + } else if (stockManagement1.getStockQuantity() > stockManagement.getStockQuantity()) { + stockManagement1.setStockQuantity(stockManagement1.getStockQuantity() - stockManagement.getStockQuantity()); + stockManagementMapper.updateById(stockManagement1); + } + else { + stockManagementMapper.deleteById(stockManagement.getId()); + } + stockOut.setProductrecordId(stockManagement1.getProductrecordId()); + stockOut.setInboundTime(stockManagement.getBoundTime()); +// 鍑哄簱鎵规鑷姩鐢熸垚 + String batchCode = "CK" + System.currentTimeMillis(); + stockOut.setInboundBatch(batchCode); + stockOut.setSupplierId(stockManagement1.getSupplierId()); + stockOut.setInboundQuantity(stockManagement.getStockQuantity()); + stockOut.setUserId(stockManagement.getUserId()); + return stockOutMapper.insert(stockOut); + } + +// 娣诲姞搴撳瓨鏂规硶 + @Override + public int addStockManage(StockManagement stockManagement) { +// 闇�瑕佸厛鍒ゆ柇閲囪喘璁板綍琛ㄤ腑鏄惁鏈夎浜у搧鐨勯噰璐褰� + LambdaQueryWrapper<ProductRecord> queryWrapper1 = new LambdaQueryWrapper<>(); + queryWrapper1.eq(ProductRecord::getId, stockManagement.getProductrecordId()); + ProductRecord productRecord = productRecordMapper.selectOne(queryWrapper1); + ProductRecordDto productRecordDto = productRecordMapper.selectProductRecordById(productRecord.getId()); + if (productRecordDto!= null) { + stockManagement.setProductrecordId(productRecordDto.getId()); + stockManagement.setBoundTime(stockManagement.getBoundTime()); + stockManagement.setSupplierId(productRecordDto.getSupplierId()); + stockManagement.setStockQuantity(stockManagement.getStockQuantity()); + stockManagement.setUserId(stockManagement.getUserId()); + return stockManagementMapper.insert(stockManagement); + }else { + throw new RuntimeException("閲囪喘璁板綍琛ㄤ腑娌℃湁璇ヤ骇鍝佺殑閲囪喘璁板綍"); + } + } + + @Override + public StockManagement getStockManageById(Long id) { + return stockManagementMapper.selectById(id); + } + + } -- Gitblit v1.9.3