囤积成本重构

This commit is contained in:
2025-12-03 10:32:06 +08:00
parent 39861ec701
commit 61453c0a82
18 changed files with 253 additions and 247 deletions

View File

@@ -88,14 +88,7 @@
{{ formatWeight(scope.row.totalNetWeight) }} {{ formatWeight(scope.row.totalNetWeight) }}
</template> </template>
</el-table-column> </el-table-column>
<el-table-column prop="avgStorageDays" label="平均在库天数" align="right" sortable="custom"> <el-table-column prop="maxStorageDays" label="在库天数" align="right" sortable="custom">
<template slot-scope="scope">
<span :class="getStorageDaysClass(scope.row.avgStorageDays)">
{{ scope.row.avgStorageDays || '-' }}
</span>
</template>
</el-table-column>
<el-table-column prop="maxStorageDays" label="最大在库天数" align="right" sortable="custom">
<template slot-scope="scope"> <template slot-scope="scope">
<span :class="getStorageDaysClass(scope.row.maxStorageDays)"> <span :class="getStorageDaysClass(scope.row.maxStorageDays)">
{{ scope.row.maxStorageDays || '-' }} {{ scope.row.maxStorageDays || '-' }}
@@ -104,7 +97,12 @@
</el-table-column> </el-table-column>
<el-table-column prop="totalCost" label="累计成本(元)" align="right" sortable="custom"> <el-table-column prop="totalCost" label="累计成本(元)" align="right" sortable="custom">
<template slot-scope="scope"> <template slot-scope="scope">
<span class="cost-total">{{ formatMoney(scope.row.totalCost) }}</span> <div style="display: flex; align-items: center; justify-content: flex-end; gap: 8px;">
<span class="cost-total">{{ formatMoney(scope.row.totalCost) }}</span>
<el-tooltip v-if="scope.row.hasNetWeightZero" content="该入场卷存在净重为空的钢卷,累计成本按毛重计算" placement="top">
<i class="el-icon-warning" style="color: #e6a23c; font-size: 16px;"></i>
</el-tooltip>
</div>
</template> </template>
</el-table-column> </el-table-column>
<el-table-column label="操作" fixed="right"> <el-table-column label="操作" fixed="right">
@@ -292,7 +290,7 @@ export default {
formatWeight(value) { formatWeight(value) {
if (!value) return '0.000' if (!value) return '0.000'
// 如果值大于1000可能是kg单位需要转换 // 如果值大于1000可能是kg单位需要转换
const weight = Number(value) > 1000 ? Number(value) / 1000 : Number(value) const weight = Number(value)
return weight.toFixed(3) return weight.toFixed(3)
}, },
formatDateTime(value) { formatDateTime(value) {

View File

@@ -4,6 +4,7 @@ import java.util.List;
import java.util.Map; import java.util.Map;
import java.util.Arrays; import java.util.Arrays;
import com.klp.service.IWmsCostCoilDailyService;
import lombok.RequiredArgsConstructor; import lombok.RequiredArgsConstructor;
import javax.servlet.http.HttpServletResponse; import javax.servlet.http.HttpServletResponse;
import javax.validation.constraints.*; import javax.validation.constraints.*;
@@ -18,9 +19,8 @@ import com.klp.common.core.validate.AddGroup;
import com.klp.common.core.validate.EditGroup; import com.klp.common.core.validate.EditGroup;
import com.klp.common.enums.BusinessType; import com.klp.common.enums.BusinessType;
import com.klp.common.utils.poi.ExcelUtil; import com.klp.common.utils.poi.ExcelUtil;
import com.klp.domain.vo.CostCoilDailyVo; import com.klp.domain.vo.WmsCostCoilDailyVo;
import com.klp.domain.bo.CostCoilDailyBo; import com.klp.domain.bo.WmsCostCoilDailyBo;
import com.klp.service.ICostCoilDailyService;
import com.klp.common.core.page.TableDataInfo; import com.klp.common.core.page.TableDataInfo;
import java.time.LocalDate; import java.time.LocalDate;
@@ -37,16 +37,16 @@ import org.springframework.format.annotation.DateTimeFormat;
@RequiredArgsConstructor @RequiredArgsConstructor
@RestController @RestController
@RequestMapping("/wms/cost/coil") @RequestMapping("/wms/cost/coil")
public class CostCoilDailyController extends BaseController { public class WmsCostCoilDailyController extends BaseController {
private final ICostCoilDailyService iCostCoilDailyService; private final IWmsCostCoilDailyService iWmsCostCoilDailyService;
/** /**
* 查询钢卷日成本记录表列表 * 查询钢卷日成本记录表列表
*/ */
@GetMapping("/list") @GetMapping("/list")
public TableDataInfo<CostCoilDailyVo> list(CostCoilDailyBo bo, PageQuery pageQuery) { public TableDataInfo<WmsCostCoilDailyVo> list(WmsCostCoilDailyBo bo, PageQuery pageQuery) {
return iCostCoilDailyService.queryPageList(bo, pageQuery); return iWmsCostCoilDailyService.queryPageList(bo, pageQuery);
} }
/** /**
@@ -54,9 +54,9 @@ public class CostCoilDailyController extends BaseController {
*/ */
@Log(title = "钢卷日成本记录表", businessType = BusinessType.EXPORT) @Log(title = "钢卷日成本记录表", businessType = BusinessType.EXPORT)
@PostMapping("/export") @PostMapping("/export")
public void export(CostCoilDailyBo bo, HttpServletResponse response) { public void export(WmsCostCoilDailyBo bo, HttpServletResponse response) {
List<CostCoilDailyVo> list = iCostCoilDailyService.queryList(bo); List<WmsCostCoilDailyVo> list = iWmsCostCoilDailyService.queryList(bo);
ExcelUtil.exportExcel(list, "钢卷日成本记录表", CostCoilDailyVo.class, response); ExcelUtil.exportExcel(list, "钢卷日成本记录表", WmsCostCoilDailyVo.class, response);
} }
/** /**
@@ -65,9 +65,9 @@ public class CostCoilDailyController extends BaseController {
* @param costId 主键 * @param costId 主键
*/ */
@GetMapping("/{costId}") @GetMapping("/{costId}")
public R<CostCoilDailyVo> getInfo(@NotNull(message = "主键不能为空") public R<WmsCostCoilDailyVo> getInfo(@NotNull(message = "主键不能为空")
@PathVariable Long costId) { @PathVariable Long costId) {
return R.ok(iCostCoilDailyService.queryById(costId)); return R.ok(iWmsCostCoilDailyService.queryById(costId));
} }
/** /**
@@ -76,8 +76,8 @@ public class CostCoilDailyController extends BaseController {
@Log(title = "钢卷日成本记录表", businessType = BusinessType.INSERT) @Log(title = "钢卷日成本记录表", businessType = BusinessType.INSERT)
@RepeatSubmit() @RepeatSubmit()
@PostMapping() @PostMapping()
public R<Void> add(@Validated(AddGroup.class) @RequestBody CostCoilDailyBo bo) { public R<Void> add(@Validated(AddGroup.class) @RequestBody WmsCostCoilDailyBo bo) {
return toAjax(iCostCoilDailyService.insertByBo(bo)); return toAjax(iWmsCostCoilDailyService.insertByBo(bo));
} }
/** /**
@@ -86,8 +86,8 @@ public class CostCoilDailyController extends BaseController {
@Log(title = "钢卷日成本记录表", businessType = BusinessType.UPDATE) @Log(title = "钢卷日成本记录表", businessType = BusinessType.UPDATE)
@RepeatSubmit() @RepeatSubmit()
@PutMapping() @PutMapping()
public R<Void> edit(@Validated(EditGroup.class) @RequestBody CostCoilDailyBo bo) { public R<Void> edit(@Validated(EditGroup.class) @RequestBody WmsCostCoilDailyBo bo) {
return toAjax(iCostCoilDailyService.updateByBo(bo)); return toAjax(iWmsCostCoilDailyService.updateByBo(bo));
} }
/** /**
@@ -99,7 +99,7 @@ public class CostCoilDailyController extends BaseController {
@DeleteMapping("/{costIds}") @DeleteMapping("/{costIds}")
public R<Void> remove(@NotEmpty(message = "主键不能为空") public R<Void> remove(@NotEmpty(message = "主键不能为空")
@PathVariable Long[] costIds) { @PathVariable Long[] costIds) {
return toAjax(iCostCoilDailyService.deleteWithValidByIds(Arrays.asList(costIds), true)); return toAjax(iWmsCostCoilDailyService.deleteWithValidByIds(Arrays.asList(costIds), true));
} }
/** /**
@@ -111,7 +111,7 @@ public class CostCoilDailyController extends BaseController {
@PostMapping("/calculate") @PostMapping("/calculate")
public R<Map<String, Object>> calculateCost(@RequestParam(required = false) Long coilId, public R<Map<String, Object>> calculateCost(@RequestParam(required = false) Long coilId,
@RequestParam(required = false) LocalDateTime calcTime) { @RequestParam(required = false) LocalDateTime calcTime) {
Map<String, Object> result = iCostCoilDailyService.calculateCost(coilId, calcTime); Map<String, Object> result = iWmsCostCoilDailyService.calculateCost(coilId, calcTime);
if (result.containsKey("error")) { if (result.containsKey("error")) {
return R.fail(result.get("error").toString()); return R.fail(result.get("error").toString());
} }
@@ -127,7 +127,6 @@ public class CostCoilDailyController extends BaseController {
@PostMapping("/batchCalculateCost") @PostMapping("/batchCalculateCost")
public R<List<Map<String, Object>>> batchCalculateCost(@RequestParam String coilIds, public R<List<Map<String, Object>>> batchCalculateCost(@RequestParam String coilIds,
@RequestParam(required = false) LocalDateTime calcTime) { @RequestParam(required = false) LocalDateTime calcTime) {
// 解析coilIds字符串为Long列表
List<Long> coilIdList = new java.util.ArrayList<>(); List<Long> coilIdList = new java.util.ArrayList<>();
if (coilIds != null && !coilIds.trim().isEmpty()) { if (coilIds != null && !coilIds.trim().isEmpty()) {
String[] ids = coilIds.split(","); String[] ids = coilIds.split(",");
@@ -136,12 +135,11 @@ public class CostCoilDailyController extends BaseController {
Long coilId = Long.parseLong(id.trim()); Long coilId = Long.parseLong(id.trim());
coilIdList.add(coilId); coilIdList.add(coilId);
} catch (NumberFormatException e) { } catch (NumberFormatException e) {
// 忽略无效的ID
} }
} }
} }
List<Map<String, Object>> results = iCostCoilDailyService.batchCalculateCost(coilIdList, calcTime); List<Map<String, Object>> results = iWmsCostCoilDailyService.batchCalculateCost(coilIdList, calcTime);
return R.ok(results); return R.ok(results);
} }
@@ -156,7 +154,7 @@ public class CostCoilDailyController extends BaseController {
if (calcDate == null) { if (calcDate == null) {
calcDate = LocalDate.now().minusDays(1); calcDate = LocalDate.now().minusDays(1);
} }
int count = iCostCoilDailyService.calculateDailyCost(calcDate); int count = iWmsCostCoilDailyService.calculateDailyCost(calcDate);
return R.ok(count); return R.ok(count);
} }
@@ -173,7 +171,7 @@ public class CostCoilDailyController extends BaseController {
@RequestParam @DateTimeFormat(pattern = "yyyy-MM-dd") LocalDate endDate, @RequestParam @DateTimeFormat(pattern = "yyyy-MM-dd") LocalDate endDate,
@RequestParam(required = false) String groupBy, @RequestParam(required = false) String groupBy,
@RequestParam(required = false) Long warehouseId) { @RequestParam(required = false) Long warehouseId) {
Map<String, Object> result = iCostCoilDailyService.queryCostSummary(startDate, endDate, groupBy, warehouseId); Map<String, Object> result = iWmsCostCoilDailyService.queryCostSummary(startDate, endDate, groupBy, warehouseId);
return R.ok(result); return R.ok(result);
} }
@@ -186,7 +184,7 @@ public class CostCoilDailyController extends BaseController {
@GetMapping("/report/trend") @GetMapping("/report/trend")
public R<List<Map<String, Object>>> queryCostTrend(@RequestParam @DateTimeFormat(pattern = "yyyy-MM-dd") LocalDate startDate, public R<List<Map<String, Object>>> queryCostTrend(@RequestParam @DateTimeFormat(pattern = "yyyy-MM-dd") LocalDate startDate,
@RequestParam @DateTimeFormat(pattern = "yyyy-MM-dd") LocalDate endDate) { @RequestParam @DateTimeFormat(pattern = "yyyy-MM-dd") LocalDate endDate) {
List<Map<String, Object>> result = iCostCoilDailyService.queryCostTrend(startDate, endDate); List<Map<String, Object>> result = iWmsCostCoilDailyService.queryCostTrend(startDate, endDate);
return R.ok(result); return R.ok(result);
} }
@@ -199,7 +197,7 @@ public class CostCoilDailyController extends BaseController {
@PostMapping("/calculateByEnterCoilNo") @PostMapping("/calculateByEnterCoilNo")
public R<Map<String, Object>> calculateCostByEnterCoilNo(@RequestParam String enterCoilNo, public R<Map<String, Object>> calculateCostByEnterCoilNo(@RequestParam String enterCoilNo,
@RequestParam(required = false) @DateTimeFormat(pattern = "yyyy-MM-dd") LocalDate calcDate) { @RequestParam(required = false) @DateTimeFormat(pattern = "yyyy-MM-dd") LocalDate calcDate) {
Map<String, Object> result = iCostCoilDailyService.calculateCostByEnterCoilNo(enterCoilNo, calcDate); Map<String, Object> result = iWmsCostCoilDailyService.calculateCostByEnterCoilNo(enterCoilNo, calcDate);
if (result.containsKey("error")) { if (result.containsKey("error")) {
return R.fail(result.get("error").toString()); return R.fail(result.get("error").toString());
} }
@@ -214,7 +212,7 @@ public class CostCoilDailyController extends BaseController {
@RequestParam(required = false) @DateTimeFormat(pattern = "yyyy-MM-dd") LocalDate calcDate, @RequestParam(required = false) @DateTimeFormat(pattern = "yyyy-MM-dd") LocalDate calcDate,
@RequestParam(required = false, defaultValue = "1") Integer pageNum, @RequestParam(required = false, defaultValue = "1") Integer pageNum,
@RequestParam(required = false, defaultValue = "20") Integer pageSize) { @RequestParam(required = false, defaultValue = "20") Integer pageSize) {
Map<String, Object> result = iCostCoilDailyService.searchMaterialCost(enterCoilNo, calcDate, pageNum, pageSize); Map<String, Object> result = iWmsCostCoilDailyService.searchMaterialCost(enterCoilNo, calcDate, pageNum, pageSize);
return R.ok(result); return R.ok(result);
} }
@@ -229,7 +227,7 @@ public class CostCoilDailyController extends BaseController {
if (calcDate == null) { if (calcDate == null) {
calcDate = LocalDate.now().minusDays(1); calcDate = LocalDate.now().minusDays(1);
} }
int count = iCostCoilDailyService.calculateDailyCostByEnterCoilNo(calcDate); int count = iWmsCostCoilDailyService.calculateDailyCostByEnterCoilNo(calcDate);
return R.ok(count); return R.ok(count);
} }
@@ -244,7 +242,7 @@ public class CostCoilDailyController extends BaseController {
public R<List<Map<String, Object>>> queryCostByEnterCoilNo(@RequestParam @DateTimeFormat(pattern = "yyyy-MM-dd") LocalDate startDate, public R<List<Map<String, Object>>> queryCostByEnterCoilNo(@RequestParam @DateTimeFormat(pattern = "yyyy-MM-dd") LocalDate startDate,
@RequestParam @DateTimeFormat(pattern = "yyyy-MM-dd") LocalDate endDate, @RequestParam @DateTimeFormat(pattern = "yyyy-MM-dd") LocalDate endDate,
@RequestParam(required = false) String enterCoilNo) { @RequestParam(required = false) String enterCoilNo) {
List<Map<String, Object>> result = iCostCoilDailyService.queryCostByEnterCoilNo(startDate, endDate, enterCoilNo); List<Map<String, Object>> result = iWmsCostCoilDailyService.queryCostByEnterCoilNo(startDate, endDate, enterCoilNo);
return R.ok(result); return R.ok(result);
} }
@@ -255,7 +253,7 @@ public class CostCoilDailyController extends BaseController {
public R<Map<String, Object>> queryStockpile(@RequestParam(required = false) String enterCoilNo, public R<Map<String, Object>> queryStockpile(@RequestParam(required = false) String enterCoilNo,
@RequestParam(required = false) String currentCoilNo, @RequestParam(required = false) String currentCoilNo,
PageQuery pageQuery) { PageQuery pageQuery) {
Map<String, Object> result = iCostCoilDailyService.queryStockpileCostList(enterCoilNo, currentCoilNo, pageQuery); Map<String, Object> result = iWmsCostCoilDailyService.queryStockpileCostList(enterCoilNo, currentCoilNo, pageQuery);
return R.ok(result); return R.ok(result);
} }
@@ -265,7 +263,7 @@ public class CostCoilDailyController extends BaseController {
*/ */
@GetMapping("/overview") @GetMapping("/overview")
public R<Map<String, Object>> overview() { public R<Map<String, Object>> overview() {
Map<String, Object> result = iCostCoilDailyService.queryOverview(); Map<String, Object> result = iWmsCostCoilDailyService.queryOverview();
return R.ok(result); return R.ok(result);
} }
} }

View File

@@ -3,6 +3,7 @@ package com.klp.controller;
import java.util.List; import java.util.List;
import java.util.Arrays; import java.util.Arrays;
import com.klp.service.IWmsCostStandardConfigService;
import lombok.RequiredArgsConstructor; import lombok.RequiredArgsConstructor;
import javax.servlet.http.HttpServletResponse; import javax.servlet.http.HttpServletResponse;
import javax.validation.constraints.*; import javax.validation.constraints.*;
@@ -17,9 +18,8 @@ import com.klp.common.core.validate.AddGroup;
import com.klp.common.core.validate.EditGroup; import com.klp.common.core.validate.EditGroup;
import com.klp.common.enums.BusinessType; import com.klp.common.enums.BusinessType;
import com.klp.common.utils.poi.ExcelUtil; import com.klp.common.utils.poi.ExcelUtil;
import com.klp.domain.vo.CostStandardConfigVo; import com.klp.domain.vo.WmsCostStandardConfigVo;
import com.klp.domain.bo.CostStandardConfigBo; import com.klp.domain.bo.WmsCostStandardConfigBo;
import com.klp.service.ICostStandardConfigService;
import com.klp.common.core.page.TableDataInfo; import com.klp.common.core.page.TableDataInfo;
/** /**
@@ -32,16 +32,16 @@ import com.klp.common.core.page.TableDataInfo;
@RequiredArgsConstructor @RequiredArgsConstructor
@RestController @RestController
@RequestMapping("/wms/cost/standard") @RequestMapping("/wms/cost/standard")
public class CostStandardConfigController extends BaseController { public class WmsCostStandardConfigController extends BaseController {
private final ICostStandardConfigService iCostStandardConfigService; private final IWmsCostStandardConfigService iWmsCostStandardConfigService;
/** /**
* 查询成本标准配置表列表 * 查询成本标准配置表列表
*/ */
@GetMapping("/list") @GetMapping("/list")
public TableDataInfo<CostStandardConfigVo> list(CostStandardConfigBo bo, PageQuery pageQuery) { public TableDataInfo<WmsCostStandardConfigVo> list(WmsCostStandardConfigBo bo, PageQuery pageQuery) {
return iCostStandardConfigService.queryPageList(bo, pageQuery); return iWmsCostStandardConfigService.queryPageList(bo, pageQuery);
} }
/** /**
@@ -49,9 +49,9 @@ public class CostStandardConfigController extends BaseController {
*/ */
@Log(title = "成本标准配置表", businessType = BusinessType.EXPORT) @Log(title = "成本标准配置表", businessType = BusinessType.EXPORT)
@PostMapping("/export") @PostMapping("/export")
public void export(CostStandardConfigBo bo, HttpServletResponse response) { public void export(WmsCostStandardConfigBo bo, HttpServletResponse response) {
List<CostStandardConfigVo> list = iCostStandardConfigService.queryList(bo); List<WmsCostStandardConfigVo> list = iWmsCostStandardConfigService.queryList(bo);
ExcelUtil.exportExcel(list, "成本标准配置表", CostStandardConfigVo.class, response); ExcelUtil.exportExcel(list, "成本标准配置表", WmsCostStandardConfigVo.class, response);
} }
/** /**
@@ -60,17 +60,17 @@ public class CostStandardConfigController extends BaseController {
* @param configId 主键 * @param configId 主键
*/ */
@GetMapping("/{configId}") @GetMapping("/{configId}")
public R<CostStandardConfigVo> getInfo(@NotNull(message = "主键不能为空") public R<WmsCostStandardConfigVo> getInfo(@NotNull(message = "主键不能为空")
@PathVariable Long configId) { @PathVariable Long configId) {
return R.ok(iCostStandardConfigService.queryById(configId)); return R.ok(iWmsCostStandardConfigService.queryById(configId));
} }
/** /**
* 查询当前有效的成本标准 * 查询当前有效的成本标准
*/ */
@GetMapping("/current") @GetMapping("/current")
public R<CostStandardConfigVo> getCurrent() { public R<WmsCostStandardConfigVo> getCurrent() {
return R.ok(iCostStandardConfigService.queryCurrentEffective()); return R.ok(iWmsCostStandardConfigService.queryCurrentEffective());
} }
/** /**
@@ -79,8 +79,8 @@ public class CostStandardConfigController extends BaseController {
@Log(title = "成本标准配置表", businessType = BusinessType.INSERT) @Log(title = "成本标准配置表", businessType = BusinessType.INSERT)
@RepeatSubmit() @RepeatSubmit()
@PostMapping() @PostMapping()
public R<Void> add(@Validated(AddGroup.class) @RequestBody CostStandardConfigBo bo) { public R<Void> add(@Validated(AddGroup.class) @RequestBody WmsCostStandardConfigBo bo) {
return toAjax(iCostStandardConfigService.insertByBo(bo)); return toAjax(iWmsCostStandardConfigService.insertByBo(bo));
} }
/** /**
@@ -89,8 +89,8 @@ public class CostStandardConfigController extends BaseController {
@Log(title = "成本标准配置表", businessType = BusinessType.UPDATE) @Log(title = "成本标准配置表", businessType = BusinessType.UPDATE)
@RepeatSubmit() @RepeatSubmit()
@PutMapping() @PutMapping()
public R<Void> edit(@Validated(EditGroup.class) @RequestBody CostStandardConfigBo bo) { public R<Void> edit(@Validated(EditGroup.class) @RequestBody WmsCostStandardConfigBo bo) {
return toAjax(iCostStandardConfigService.updateByBo(bo)); return toAjax(iWmsCostStandardConfigService.updateByBo(bo));
} }
/** /**
@@ -102,7 +102,7 @@ public class CostStandardConfigController extends BaseController {
@DeleteMapping("/{configIds}") @DeleteMapping("/{configIds}")
public R<Void> remove(@NotEmpty(message = "主键不能为空") public R<Void> remove(@NotEmpty(message = "主键不能为空")
@PathVariable Long[] configIds) { @PathVariable Long[] configIds) {
return toAjax(iCostStandardConfigService.deleteWithValidByIds(Arrays.asList(configIds), true)); return toAjax(iWmsCostStandardConfigService.deleteWithValidByIds(Arrays.asList(configIds), true));
} }
} }

View File

@@ -9,15 +9,15 @@ import java.math.BigDecimal;
import java.time.LocalDate; import java.time.LocalDate;
/** /**
* 钢卷日成本记录表对象 cost_coil_daily * 钢卷日成本记录表对象 wms_cost_coil_daily
* *
* @author klp * @author klp
* @date 2025-11-25 * @date 2025-11-25
*/ */
@Data @Data
@EqualsAndHashCode(callSuper = true) @EqualsAndHashCode(callSuper = true)
@TableName("cost_coil_daily") @TableName("wms_cost_coil_daily")
public class CostCoilDaily extends BaseEntity { public class WmsCostCoilDaily extends BaseEntity {
private static final long serialVersionUID = 1L; private static final long serialVersionUID = 1L;

View File

@@ -9,15 +9,15 @@ import java.math.BigDecimal;
import java.time.LocalDate; import java.time.LocalDate;
/** /**
* 成本标准配置表对象 cost_standard_config * 成本标准配置表对象 wms_cost_standard_config
* *
* @author klp * @author klp
* @date 2025-11-25 * @date 2025-11-25
*/ */
@Data @Data
@EqualsAndHashCode(callSuper = true) @EqualsAndHashCode(callSuper = true)
@TableName("cost_standard_config") @TableName("wms_cost_standard_config")
public class CostStandardConfig extends BaseEntity { public class WmsCostStandardConfig extends BaseEntity {
private static final long serialVersionUID = 1L; private static final long serialVersionUID = 1L;

View File

@@ -8,14 +8,14 @@ import java.math.BigDecimal;
import java.time.LocalDate; import java.time.LocalDate;
/** /**
* 钢卷日成本记录表业务对象 cost_coil_daily * 钢卷日成本记录表业务对象 wms_cost_coil_daily
* *
* @author klp * @author klp
* @date 2025-11-25 * @date 2025-11-25
*/ */
@Data @Data
@EqualsAndHashCode(callSuper = true) @EqualsAndHashCode(callSuper = true)
public class CostCoilDailyBo extends BaseEntity { public class WmsCostCoilDailyBo extends BaseEntity {
/** /**
* 主键ID * 主键ID

View File

@@ -8,14 +8,14 @@ import java.math.BigDecimal;
import java.time.LocalDate; import java.time.LocalDate;
/** /**
* 成本标准配置表业务对象 cost_standard_config * 成本标准配置表业务对象 wms_cost_standard_config
* *
* @author klp * @author klp
* @date 2025-11-25 * @date 2025-11-25
*/ */
@Data @Data
@EqualsAndHashCode(callSuper = true) @EqualsAndHashCode(callSuper = true)
public class CostStandardConfigBo extends BaseEntity { public class WmsCostStandardConfigBo extends BaseEntity {
/** /**
* 主键ID * 主键ID

View File

@@ -8,14 +8,14 @@ import java.math.BigDecimal;
import java.time.LocalDate; import java.time.LocalDate;
/** /**
* 钢卷日成本记录表视图对象 cost_coil_daily * 钢卷日成本记录表视图对象 wms_cost_coil_daily
* *
* @author klp * @author klp
* @date 2025-11-25 * @date 2025-11-25
*/ */
@Data @Data
@ExcelIgnoreUnannotated @ExcelIgnoreUnannotated
public class CostCoilDailyVo { public class WmsCostCoilDailyVo {
/** /**
* 主键ID * 主键ID

View File

@@ -8,14 +8,14 @@ import java.math.BigDecimal;
import java.time.LocalDate; import java.time.LocalDate;
/** /**
* 成本标准配置表视图对象 cost_standard_config * 成本标准配置表视图对象 wms_cost_standard_config
* *
* @author klp * @author klp
* @date 2025-11-25 * @date 2025-11-25
*/ */
@Data @Data
@ExcelIgnoreUnannotated @ExcelIgnoreUnannotated
public class CostStandardConfigVo { public class WmsCostStandardConfigVo {
/** /**
* 主键ID * 主键ID

View File

@@ -1,8 +1,8 @@
package com.klp.mapper; package com.klp.mapper;
import com.klp.common.core.mapper.BaseMapperPlus; import com.klp.common.core.mapper.BaseMapperPlus;
import com.klp.domain.CostCoilDaily; import com.klp.domain.WmsCostCoilDaily;
import com.klp.domain.vo.CostCoilDailyVo; import com.klp.domain.vo.WmsCostCoilDailyVo;
import org.apache.ibatis.annotations.Param; import org.apache.ibatis.annotations.Param;
import java.time.LocalDate; import java.time.LocalDate;
@@ -15,7 +15,7 @@ import java.util.Map;
* @author klp * @author klp
* @date 2025-11-25 * @date 2025-11-25
*/ */
public interface CostCoilDailyMapper extends BaseMapperPlus<CostCoilDailyMapper, CostCoilDaily, CostCoilDailyVo> { public interface WmsCostCoilDailyMapper extends BaseMapperPlus<WmsCostCoilDailyMapper, WmsCostCoilDaily, WmsCostCoilDailyVo> {
/** /**
* 查询成本统计汇总 * 查询成本统计汇总

View File

@@ -1,7 +1,7 @@
package com.klp.mapper; package com.klp.mapper;
import com.klp.domain.CostStandardConfig; import com.klp.domain.WmsCostStandardConfig;
import com.klp.domain.vo.CostStandardConfigVo; import com.klp.domain.vo.WmsCostStandardConfigVo;
import com.klp.common.core.mapper.BaseMapperPlus; import com.klp.common.core.mapper.BaseMapperPlus;
import org.apache.ibatis.annotations.Param; import org.apache.ibatis.annotations.Param;
@@ -13,7 +13,7 @@ import java.time.LocalDate;
* @author klp * @author klp
* @date 2025-11-25 * @date 2025-11-25
*/ */
public interface CostStandardConfigMapper extends BaseMapperPlus<CostStandardConfigMapper, CostStandardConfig, CostStandardConfigVo> { public interface WmsCostStandardConfigMapper extends BaseMapperPlus<WmsCostStandardConfigMapper, WmsCostStandardConfig, WmsCostStandardConfigVo> {
/** /**
* 查询指定日期的有效成本标准 * 查询指定日期的有效成本标准
@@ -21,13 +21,13 @@ public interface CostStandardConfigMapper extends BaseMapperPlus<CostStandardCon
* @param date 日期 * @param date 日期
* @return 成本标准配置 * @return 成本标准配置
*/ */
CostStandardConfigVo selectEffectiveByDate(@Param("date") LocalDate date); WmsCostStandardConfigVo selectEffectiveByDate(@Param("date") LocalDate date);
/** /**
* 查询当前有效的成本标准 * 查询当前有效的成本标准
* *
* @return 成本标准配置 * @return 成本标准配置
*/ */
CostStandardConfigVo selectCurrentEffective(); WmsCostStandardConfigVo selectCurrentEffective();
} }

View File

@@ -1,9 +1,10 @@
package com.klp.service; package com.klp.service;
import com.klp.domain.vo.CostCoilDailyVo; import com.klp.domain.vo.WmsCostCoilDailyVo;
import com.klp.domain.bo.CostCoilDailyBo; import com.klp.domain.bo.WmsCostCoilDailyBo;
import com.klp.common.core.page.TableDataInfo; import com.klp.common.core.page.TableDataInfo;
import com.klp.common.core.domain.PageQuery; import com.klp.common.core.domain.PageQuery;
import com.klp.domain.vo.WmsCostCoilDailyVo;
import java.time.LocalDate; import java.time.LocalDate;
import java.util.Collection; import java.util.Collection;
@@ -16,32 +17,32 @@ import java.util.Map;
* @author klp * @author klp
* @date 2025-11-25 * @date 2025-11-25
*/ */
public interface ICostCoilDailyService { public interface IWmsCostCoilDailyService {
/** /**
* 查询钢卷日成本记录表 * 查询钢卷日成本记录表
*/ */
CostCoilDailyVo queryById(Long costId); WmsCostCoilDailyVo queryById(Long costId);
/** /**
* 查询钢卷日成本记录表列表 * 查询钢卷日成本记录表列表
*/ */
TableDataInfo<CostCoilDailyVo> queryPageList(CostCoilDailyBo bo, PageQuery pageQuery); TableDataInfo<WmsCostCoilDailyVo> queryPageList(WmsCostCoilDailyBo bo, PageQuery pageQuery);
/** /**
* 查询钢卷日成本记录表列表 * 查询钢卷日成本记录表列表
*/ */
List<CostCoilDailyVo> queryList(CostCoilDailyBo bo); List<WmsCostCoilDailyVo> queryList(WmsCostCoilDailyBo bo);
/** /**
* 新增钢卷日成本记录表 * 新增钢卷日成本记录表
*/ */
Boolean insertByBo(CostCoilDailyBo bo); Boolean insertByBo(WmsCostCoilDailyBo bo);
/** /**
* 修改钢卷日成本记录表 * 修改钢卷日成本记录表
*/ */
Boolean updateByBo(CostCoilDailyBo bo); Boolean updateByBo(WmsCostCoilDailyBo bo);
/** /**
* 校验并批量删除钢卷日成本记录表信息 * 校验并批量删除钢卷日成本记录表信息

View File

@@ -1,7 +1,7 @@
package com.klp.service; package com.klp.service;
import com.klp.domain.vo.CostStandardConfigVo; import com.klp.domain.vo.WmsCostStandardConfigVo;
import com.klp.domain.bo.CostStandardConfigBo; import com.klp.domain.bo.WmsCostStandardConfigBo;
import com.klp.common.core.page.TableDataInfo; import com.klp.common.core.page.TableDataInfo;
import com.klp.common.core.domain.PageQuery; import com.klp.common.core.domain.PageQuery;
@@ -15,32 +15,32 @@ import java.util.List;
* @author klp * @author klp
* @date 2025-11-25 * @date 2025-11-25
*/ */
public interface ICostStandardConfigService { public interface IWmsCostStandardConfigService {
/** /**
* 查询成本标准配置表 * 查询成本标准配置表
*/ */
CostStandardConfigVo queryById(Long configId); WmsCostStandardConfigVo queryById(Long configId);
/** /**
* 查询成本标准配置表列表 * 查询成本标准配置表列表
*/ */
TableDataInfo<CostStandardConfigVo> queryPageList(CostStandardConfigBo bo, PageQuery pageQuery); TableDataInfo<WmsCostStandardConfigVo> queryPageList(WmsCostStandardConfigBo bo, PageQuery pageQuery);
/** /**
* 查询成本标准配置表列表 * 查询成本标准配置表列表
*/ */
List<CostStandardConfigVo> queryList(CostStandardConfigBo bo); List<WmsCostStandardConfigVo> queryList(WmsCostStandardConfigBo bo);
/** /**
* 新增成本标准配置表 * 新增成本标准配置表
*/ */
Boolean insertByBo(CostStandardConfigBo bo); Boolean insertByBo(WmsCostStandardConfigBo bo);
/** /**
* 修改成本标准配置表 * 修改成本标准配置表
*/ */
Boolean updateByBo(CostStandardConfigBo bo); Boolean updateByBo(WmsCostStandardConfigBo bo);
/** /**
* 校验并批量删除成本标准配置表信息 * 校验并批量删除成本标准配置表信息
@@ -52,7 +52,7 @@ public interface ICostStandardConfigService {
* *
* @return 成本标准配置 * @return 成本标准配置
*/ */
CostStandardConfigVo queryCurrentEffective(); WmsCostStandardConfigVo queryCurrentEffective();
/** /**
* 查询指定日期的有效成本标准 * 查询指定日期的有效成本标准
@@ -60,6 +60,6 @@ public interface ICostStandardConfigService {
* @param date 日期 * @param date 日期
* @return 成本标准配置 * @return 成本标准配置
*/ */
CostStandardConfigVo queryEffectiveByDate(LocalDate date); WmsCostStandardConfigVo queryEffectiveByDate(LocalDate date);
} }

View File

@@ -7,19 +7,19 @@ import com.baomidou.mybatisplus.core.toolkit.Wrappers;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page; import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.klp.common.core.page.TableDataInfo; import com.klp.common.core.page.TableDataInfo;
import com.klp.common.core.domain.PageQuery; import com.klp.common.core.domain.PageQuery;
import com.klp.domain.WmsCostCoilDaily;
import com.klp.domain.bo.WmsCostCoilDailyBo;
import com.klp.domain.vo.WmsCostCoilDailyVo;
import com.klp.domain.vo.WmsCostStandardConfigVo;
import com.klp.mapper.WmsCostCoilDailyMapper;
import lombok.RequiredArgsConstructor; import lombok.RequiredArgsConstructor;
import lombok.extern.slf4j.Slf4j; import lombok.extern.slf4j.Slf4j;
import org.springframework.stereotype.Service; import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional; import org.springframework.transaction.annotation.Transactional;
import com.klp.domain.bo.CostCoilDailyBo;
import com.klp.domain.vo.CostCoilDailyVo;
import com.klp.domain.CostCoilDaily;
import com.klp.domain.WmsMaterialCoil; import com.klp.domain.WmsMaterialCoil;
import com.klp.domain.vo.CostStandardConfigVo;
import com.klp.mapper.CostCoilDailyMapper;
import com.klp.mapper.WmsMaterialCoilMapper; import com.klp.mapper.WmsMaterialCoilMapper;
import com.klp.service.ICostCoilDailyService; import com.klp.service.IWmsCostCoilDailyService;
import com.klp.service.ICostStandardConfigService; import com.klp.service.IWmsCostStandardConfigService;
import java.math.BigDecimal; import java.math.BigDecimal;
import java.math.RoundingMode; import java.math.RoundingMode;
@@ -38,17 +38,17 @@ import org.apache.commons.lang3.StringUtils;
@Slf4j @Slf4j
@RequiredArgsConstructor @RequiredArgsConstructor
@Service @Service
public class CostCoilDailyServiceImpl implements ICostCoilDailyService { public class WmsCostCoilDailyServiceImpl implements IWmsCostCoilDailyService {
private final CostCoilDailyMapper baseMapper; private final WmsCostCoilDailyMapper baseMapper;
private final WmsMaterialCoilMapper coilMapper; private final WmsMaterialCoilMapper coilMapper;
private final ICostStandardConfigService costStandardConfigService; private final IWmsCostStandardConfigService costStandardConfigService;
/** /**
* 查询钢卷日成本记录表 * 查询钢卷日成本记录表
*/ */
@Override @Override
public CostCoilDailyVo queryById(Long costId) { public WmsCostCoilDailyVo queryById(Long costId) {
return baseMapper.selectVoById(costId); return baseMapper.selectVoById(costId);
} }
@@ -56,9 +56,9 @@ public class CostCoilDailyServiceImpl implements ICostCoilDailyService {
* 查询钢卷日成本记录表列表 * 查询钢卷日成本记录表列表
*/ */
@Override @Override
public TableDataInfo<CostCoilDailyVo> queryPageList(CostCoilDailyBo bo, PageQuery pageQuery) { public TableDataInfo<WmsCostCoilDailyVo> queryPageList(WmsCostCoilDailyBo bo, PageQuery pageQuery) {
LambdaQueryWrapper<CostCoilDaily> lqw = buildQueryWrapper(bo); LambdaQueryWrapper<WmsCostCoilDaily> lqw = buildQueryWrapper(bo);
Page<CostCoilDailyVo> result = baseMapper.selectVoPage(pageQuery.build(), lqw); Page<WmsCostCoilDailyVo> result = baseMapper.selectVoPage(pageQuery.build(), lqw);
return TableDataInfo.build(result); return TableDataInfo.build(result);
} }
@@ -66,28 +66,28 @@ public class CostCoilDailyServiceImpl implements ICostCoilDailyService {
* 查询钢卷日成本记录表列表 * 查询钢卷日成本记录表列表
*/ */
@Override @Override
public List<CostCoilDailyVo> queryList(CostCoilDailyBo bo) { public List<WmsCostCoilDailyVo> queryList(WmsCostCoilDailyBo bo) {
LambdaQueryWrapper<CostCoilDaily> lqw = buildQueryWrapper(bo); LambdaQueryWrapper<WmsCostCoilDaily> lqw = buildQueryWrapper(bo);
return baseMapper.selectVoList(lqw); return baseMapper.selectVoList(lqw);
} }
private LambdaQueryWrapper<CostCoilDaily> buildQueryWrapper(CostCoilDailyBo bo) { private LambdaQueryWrapper<WmsCostCoilDaily> buildQueryWrapper(WmsCostCoilDailyBo bo) {
LambdaQueryWrapper<CostCoilDaily> lqw = Wrappers.lambdaQuery(); LambdaQueryWrapper<WmsCostCoilDaily> lqw = Wrappers.lambdaQuery();
lqw.eq(bo.getCostId() != null, CostCoilDaily::getCostId, bo.getCostId()); lqw.eq(bo.getCostId() != null, WmsCostCoilDaily::getCostId, bo.getCostId());
lqw.eq(bo.getCoilId() != null, CostCoilDaily::getCoilId, bo.getCoilId()); lqw.eq(bo.getCoilId() != null, WmsCostCoilDaily::getCoilId, bo.getCoilId());
lqw.like(bo.getCurrentCoilNo() != null, CostCoilDaily::getCurrentCoilNo, bo.getCurrentCoilNo()); lqw.like(bo.getCurrentCoilNo() != null, WmsCostCoilDaily::getCurrentCoilNo, bo.getCurrentCoilNo());
lqw.eq(bo.getCalcDate() != null, CostCoilDaily::getCalcDate, bo.getCalcDate()); lqw.eq(bo.getCalcDate() != null, WmsCostCoilDaily::getCalcDate, bo.getCalcDate());
lqw.eq(bo.getWarehouseId() != null, CostCoilDaily::getWarehouseId, bo.getWarehouseId()); lqw.eq(bo.getWarehouseId() != null, WmsCostCoilDaily::getWarehouseId, bo.getWarehouseId());
lqw.eq(bo.getItemType() != null, CostCoilDaily::getItemType, bo.getItemType()); lqw.eq(bo.getItemType() != null, WmsCostCoilDaily::getItemType, bo.getItemType());
lqw.eq(bo.getMaterialType() != null, CostCoilDaily::getMaterialType, bo.getMaterialType()); lqw.eq(bo.getMaterialType() != null, WmsCostCoilDaily::getMaterialType, bo.getMaterialType());
if (bo.getStartDate() != null) { if (bo.getStartDate() != null) {
lqw.ge(CostCoilDaily::getCalcDate, bo.getStartDate()); lqw.ge(WmsCostCoilDaily::getCalcDate, bo.getStartDate());
} }
if (bo.getEndDate() != null) { if (bo.getEndDate() != null) {
lqw.le(CostCoilDaily::getCalcDate, bo.getEndDate()); lqw.le(WmsCostCoilDaily::getCalcDate, bo.getEndDate());
} }
lqw.orderByDesc(CostCoilDaily::getCalcDate); lqw.orderByDesc(WmsCostCoilDaily::getCalcDate);
lqw.orderByDesc(CostCoilDaily::getCostId); lqw.orderByDesc(WmsCostCoilDaily::getCostId);
return lqw; return lqw;
} }
@@ -95,8 +95,8 @@ public class CostCoilDailyServiceImpl implements ICostCoilDailyService {
* 新增钢卷日成本记录表 * 新增钢卷日成本记录表
*/ */
@Override @Override
public Boolean insertByBo(CostCoilDailyBo bo) { public Boolean insertByBo(WmsCostCoilDailyBo bo) {
CostCoilDaily add = BeanUtil.toBean(bo, CostCoilDaily.class); WmsCostCoilDaily add = BeanUtil.toBean(bo, WmsCostCoilDaily.class);
validEntityBeforeSave(add); validEntityBeforeSave(add);
return baseMapper.insert(add) > 0; return baseMapper.insert(add) > 0;
} }
@@ -105,8 +105,8 @@ public class CostCoilDailyServiceImpl implements ICostCoilDailyService {
* 修改钢卷日成本记录表 * 修改钢卷日成本记录表
*/ */
@Override @Override
public Boolean updateByBo(CostCoilDailyBo bo) { public Boolean updateByBo(WmsCostCoilDailyBo bo) {
CostCoilDaily update = BeanUtil.toBean(bo, CostCoilDaily.class); WmsCostCoilDaily update = BeanUtil.toBean(bo, WmsCostCoilDaily.class);
validEntityBeforeSave(update); validEntityBeforeSave(update);
return baseMapper.updateById(update) > 0; return baseMapper.updateById(update) > 0;
} }
@@ -114,7 +114,7 @@ public class CostCoilDailyServiceImpl implements ICostCoilDailyService {
/** /**
* 保存前的数据校验 * 保存前的数据校验
*/ */
private void validEntityBeforeSave(CostCoilDaily entity) { private void validEntityBeforeSave(WmsCostCoilDaily entity) {
// TODO 做一些数据校验,如唯一约束 // TODO 做一些数据校验,如唯一约束
} }
@@ -161,30 +161,30 @@ public class CostCoilDailyServiceImpl implements ICostCoilDailyService {
} }
// 3. 计算在库天数 // 3. 计算在库天数
LocalDate startDate = coil.getCreateTime() != null LocalDate startDate = coil.getCreateTime() != null
? coil.getCreateTime().toInstant().atZone(java.time.ZoneId.systemDefault()).toLocalDate() ? coil.getCreateTime().toInstant().atZone(java.time.ZoneId.systemDefault()).toLocalDate()
: LocalDate.now(); : LocalDate.now();
LocalDate endDate = calcTime != null ? calcTime.toLocalDate() : LocalDate.now(); LocalDate endDate = calcTime != null ? calcTime.toLocalDate() : LocalDate.now();
long days = ChronoUnit.DAYS.between(startDate, endDate) + 1; long days = ChronoUnit.DAYS.between(startDate, endDate) + 1;
if (days < 1) { if (days < 1) {
days = 1; // 不足一天按一天计算 days = 1; // 不足一天按一天计算
} }
// 4. 获取成本标准使用入库日期的成本标准 // 4. 获取成本标准使用入库日期的成本标准
CostStandardConfigVo costStandard = costStandardConfigService.queryEffectiveByDate(startDate); WmsCostStandardConfigVo costStandard = costStandardConfigService.queryEffectiveByDate(startDate);
if (costStandard == null) { if (costStandard == null) {
// 如果没有找到对应日期的标准使用当前有效的标准 // 如果没有找到对应日期的标准使用当前有效的标准
costStandard = costStandardConfigService.queryCurrentEffective(); costStandard = costStandardConfigService.queryCurrentEffective();
} }
if (costStandard == null || costStandard.getUnitCost() == null) { if (costStandard == null || costStandard.getUnitCost() == null) {
result.put("error", "未找到有效的成本标准配置"); result.put("error", "未找到有效的成本标准配置");
return result; return result;
} }
BigDecimal unitCost = costStandard.getUnitCost(); BigDecimal unitCost = costStandard.getUnitCost();
// 5. 计算成本按毛重优先 // 5. 计算成本按毛重优先
BigDecimal dailyCost = weightContext.getCostTon().multiply(unitCost).setScale(2, RoundingMode.HALF_UP); BigDecimal dailyCost = weightContext.getCostTon().multiply(unitCost).setScale(2, RoundingMode.HALF_UP);
BigDecimal totalCost = dailyCost.multiply(BigDecimal.valueOf(days)).setScale(2, RoundingMode.HALF_UP); BigDecimal totalCost = dailyCost.multiply(BigDecimal.valueOf(days)).setScale(2, RoundingMode.HALF_UP);
@@ -216,36 +216,36 @@ public class CostCoilDailyServiceImpl implements ICostCoilDailyService {
@Override @Override
public List<Map<String, Object>> batchCalculateCost(List<Long> coilIds, LocalDateTime calcTime) { public List<Map<String, Object>> batchCalculateCost(List<Long> coilIds, LocalDateTime calcTime) {
List<Map<String, Object>> results = new ArrayList<>(); List<Map<String, Object>> results = new ArrayList<>();
if (coilIds == null || coilIds.isEmpty()) { if (coilIds == null || coilIds.isEmpty()) {
return results; return results;
} }
// 批量查询钢卷信息 // 批量查询钢卷信息
QueryWrapper<WmsMaterialCoil> queryWrapper = new QueryWrapper<>(); QueryWrapper<WmsMaterialCoil> queryWrapper = new QueryWrapper<>();
queryWrapper.in("coil_id", coilIds); queryWrapper.in("coil_id", coilIds);
List<WmsMaterialCoil> coils = coilMapper.selectList(queryWrapper); List<WmsMaterialCoil> coils = coilMapper.selectList(queryWrapper);
if (coils == null || coils.isEmpty()) { if (coils == null || coils.isEmpty()) {
return results; return results;
} }
// 获取成本标准统一使用当前有效的标准因为批量计算时可能跨多个日期 // 获取成本标准统一使用当前有效的标准因为批量计算时可能跨多个日期
LocalDate calcDate = calcTime != null ? calcTime.toLocalDate() : LocalDate.now(); LocalDate calcDate = calcTime != null ? calcTime.toLocalDate() : LocalDate.now();
CostStandardConfigVo costStandard = costStandardConfigService.queryEffectiveByDate(calcDate); WmsCostStandardConfigVo costStandard = costStandardConfigService.queryEffectiveByDate(calcDate);
if (costStandard == null) { if (costStandard == null) {
costStandard = costStandardConfigService.queryCurrentEffective(); costStandard = costStandardConfigService.queryCurrentEffective();
} }
BigDecimal unitCost = null; BigDecimal unitCost = null;
if (costStandard != null && costStandard.getUnitCost() != null) { if (costStandard != null && costStandard.getUnitCost() != null) {
unitCost = costStandard.getUnitCost(); unitCost = costStandard.getUnitCost();
} }
// 遍历计算每个钢卷的成本 // 遍历计算每个钢卷的成本
for (WmsMaterialCoil coil : coils) { for (WmsMaterialCoil coil : coils) {
Map<String, Object> result = new HashMap<>(); Map<String, Object> result = new HashMap<>();
// 验证是否为计算对象data_type=1, export_time IS NULL // 验证是否为计算对象data_type=1, export_time IS NULL
if (coil.getDataType() == null || coil.getDataType() != 1) { if (coil.getDataType() == null || coil.getDataType() != 1) {
result.put("coilId", coil.getCoilId()); result.put("coilId", coil.getCoilId());
@@ -254,7 +254,7 @@ public class CostCoilDailyServiceImpl implements ICostCoilDailyService {
results.add(result); results.add(result);
continue; continue;
} }
if (coil.getExportTime() != null) { if (coil.getExportTime() != null) {
result.put("coilId", coil.getCoilId()); result.put("coilId", coil.getCoilId());
result.put("coilNo", coil.getCurrentCoilNo()); result.put("coilNo", coil.getCurrentCoilNo());
@@ -262,7 +262,7 @@ public class CostCoilDailyServiceImpl implements ICostCoilDailyService {
results.add(result); results.add(result);
continue; continue;
} }
WeightContext weightContext = resolveWeightContext(coil); WeightContext weightContext = resolveWeightContext(coil);
if (!weightContext.isValid()) { if (!weightContext.isValid()) {
result.put("coilId", coil.getCoilId()); result.put("coilId", coil.getCoilId());
@@ -271,32 +271,32 @@ public class CostCoilDailyServiceImpl implements ICostCoilDailyService {
results.add(result); results.add(result);
continue; continue;
} }
// 计算在库天数 // 计算在库天数
LocalDate startDate = coil.getCreateTime() != null LocalDate startDate = coil.getCreateTime() != null
? coil.getCreateTime().toInstant().atZone(java.time.ZoneId.systemDefault()).toLocalDate() ? coil.getCreateTime().toInstant().atZone(java.time.ZoneId.systemDefault()).toLocalDate()
: LocalDate.now(); : LocalDate.now();
LocalDate endDate = calcTime != null ? calcTime.toLocalDate() : LocalDate.now(); LocalDate endDate = calcTime != null ? calcTime.toLocalDate() : LocalDate.now();
long days = ChronoUnit.DAYS.between(startDate, endDate) + 1; long days = ChronoUnit.DAYS.between(startDate, endDate) + 1;
if (days < 1) { if (days < 1) {
days = 1; // 不足一天按一天计算 days = 1; // 不足一天按一天计算
} }
// 如果统一标准为空尝试使用入库日期的标准 // 如果统一标准为空尝试使用入库日期的标准
BigDecimal finalUnitCost = unitCost; BigDecimal finalUnitCost = unitCost;
if (finalUnitCost == null) { if (finalUnitCost == null) {
CostStandardConfigVo startDateStandard = costStandardConfigService.queryEffectiveByDate(startDate); WmsCostStandardConfigVo startDateStandard = costStandardConfigService.queryEffectiveByDate(startDate);
if (startDateStandard != null && startDateStandard.getUnitCost() != null) { if (startDateStandard != null && startDateStandard.getUnitCost() != null) {
finalUnitCost = startDateStandard.getUnitCost(); finalUnitCost = startDateStandard.getUnitCost();
} else { } else {
CostStandardConfigVo currentStandard = costStandardConfigService.queryCurrentEffective(); WmsCostStandardConfigVo currentStandard = costStandardConfigService.queryCurrentEffective();
if (currentStandard != null && currentStandard.getUnitCost() != null) { if (currentStandard != null && currentStandard.getUnitCost() != null) {
finalUnitCost = currentStandard.getUnitCost(); finalUnitCost = currentStandard.getUnitCost();
} }
} }
} }
if (finalUnitCost == null) { if (finalUnitCost == null) {
result.put("coilId", coil.getCoilId()); result.put("coilId", coil.getCoilId());
result.put("coilNo", coil.getCurrentCoilNo()); result.put("coilNo", coil.getCurrentCoilNo());
@@ -304,11 +304,11 @@ public class CostCoilDailyServiceImpl implements ICostCoilDailyService {
results.add(result); results.add(result);
continue; continue;
} }
// 计算成本毛重优先 // 计算成本毛重优先
BigDecimal dailyCost = weightContext.getCostTon().multiply(finalUnitCost).setScale(2, RoundingMode.HALF_UP); BigDecimal dailyCost = weightContext.getCostTon().multiply(finalUnitCost).setScale(2, RoundingMode.HALF_UP);
BigDecimal totalCost = dailyCost.multiply(BigDecimal.valueOf(days)).setScale(2, RoundingMode.HALF_UP); BigDecimal totalCost = dailyCost.multiply(BigDecimal.valueOf(days)).setScale(2, RoundingMode.HALF_UP);
// 返回结果 // 返回结果
result.put("coilId", coil.getCoilId()); result.put("coilId", coil.getCoilId());
result.put("coilNo", coil.getCurrentCoilNo()); result.put("coilNo", coil.getCurrentCoilNo());
@@ -326,10 +326,10 @@ public class CostCoilDailyServiceImpl implements ICostCoilDailyService {
result.put("itemType", coil.getItemType()); result.put("itemType", coil.getItemType());
result.put("materialType", coil.getMaterialType()); result.put("materialType", coil.getMaterialType());
result.put("createTime", coil.getCreateTime()); result.put("createTime", coil.getCreateTime());
results.add(result); results.add(result);
} }
return results; return results;
} }
@@ -355,7 +355,7 @@ public class CostCoilDailyServiceImpl implements ICostCoilDailyService {
log.info("找到 {} 个需要计算成本的钢卷", coils.size()); log.info("找到 {} 个需要计算成本的钢卷", coils.size());
// 2. 获取成本标准 // 2. 获取成本标准
CostStandardConfigVo costStandard = costStandardConfigService.queryEffectiveByDate(calcDate); WmsCostStandardConfigVo costStandard = costStandardConfigService.queryEffectiveByDate(calcDate);
if (costStandard == null) { if (costStandard == null) {
costStandard = costStandardConfigService.queryCurrentEffective(); costStandard = costStandardConfigService.queryCurrentEffective();
} }
@@ -390,7 +390,7 @@ public class CostCoilDailyServiceImpl implements ICostCoilDailyService {
BigDecimal totalCost = dailyCost.multiply(BigDecimal.valueOf(days)).setScale(2, RoundingMode.HALF_UP); BigDecimal totalCost = dailyCost.multiply(BigDecimal.valueOf(days)).setScale(2, RoundingMode.HALF_UP);
// 4. 保存成本记录 // 4. 保存成本记录
CostCoilDaily costRecord = new CostCoilDaily(); WmsCostCoilDaily costRecord = new WmsCostCoilDaily();
costRecord.setCoilId(coil.getCoilId()); costRecord.setCoilId(coil.getCoilId());
costRecord.setCurrentCoilNo(coil.getCurrentCoilNo()); costRecord.setCurrentCoilNo(coil.getCurrentCoilNo());
costRecord.setCalcDate(calcDate); costRecord.setCalcDate(calcDate);
@@ -517,7 +517,7 @@ public class CostCoilDailyServiceImpl implements ICostCoilDailyService {
} }
// 获取成本标准 // 获取成本标准
CostStandardConfigVo costStandard = costStandardConfigService.queryEffectiveByDate(startDate); WmsCostStandardConfigVo costStandard = costStandardConfigService.queryEffectiveByDate(startDate);
if (costStandard == null) { if (costStandard == null) {
costStandard = costStandardConfigService.queryCurrentEffective(); costStandard = costStandardConfigService.queryCurrentEffective();
} }
@@ -611,7 +611,7 @@ public class CostCoilDailyServiceImpl implements ICostCoilDailyService {
// 计算该入场钢卷号的成本 // 计算该入场钢卷号的成本
Map<String, Object> costResult = calculateCostByEnterCoilNo(enterCoilNo, calcDate); Map<String, Object> costResult = calculateCostByEnterCoilNo(enterCoilNo, calcDate);
if (costResult.containsKey("error")) { if (costResult.containsKey("error")) {
log.warn("计算入场钢卷号 {} 的成本时发生错误: {}", enterCoilNo, costResult.get("error")); log.warn("计算入场钢卷号 {} 的成本时发生错误: {}", enterCoilNo, costResult.get("error"));
continue; continue;
@@ -671,7 +671,7 @@ public class CostCoilDailyServiceImpl implements ICostCoilDailyService {
} }
// 获取成本标准 // 获取成本标准
CostStandardConfigVo costStandard = costStandardConfigService.queryEffectiveByDate(startDate); WmsCostStandardConfigVo costStandard = costStandardConfigService.queryEffectiveByDate(startDate);
if (costStandard == null) { if (costStandard == null) {
costStandard = costStandardConfigService.queryCurrentEffective(); costStandard = costStandardConfigService.queryCurrentEffective();
} }
@@ -693,7 +693,7 @@ public class CostCoilDailyServiceImpl implements ICostCoilDailyService {
BigDecimal totalCost = dailyCost.multiply(BigDecimal.valueOf(days)).setScale(2, RoundingMode.HALF_UP); BigDecimal totalCost = dailyCost.multiply(BigDecimal.valueOf(days)).setScale(2, RoundingMode.HALF_UP);
// 保存成本记录 // 保存成本记录
CostCoilDaily costRecord = new CostCoilDaily(); WmsCostCoilDaily costRecord = new WmsCostCoilDaily();
costRecord.setCoilId(coil.getCoilId()); costRecord.setCoilId(coil.getCoilId());
costRecord.setCurrentCoilNo(coil.getCurrentCoilNo()); costRecord.setCurrentCoilNo(coil.getCurrentCoilNo());
costRecord.setCalcDate(calcDate); costRecord.setCalcDate(calcDate);

View File

@@ -6,14 +6,15 @@ import com.baomidou.mybatisplus.core.toolkit.Wrappers;
import com.klp.common.core.page.TableDataInfo; import com.klp.common.core.page.TableDataInfo;
import com.klp.common.core.domain.PageQuery; import com.klp.common.core.domain.PageQuery;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page; import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.klp.domain.WmsCostStandardConfig;
import com.klp.domain.vo.WmsCostStandardConfigVo;
import com.klp.mapper.WmsCostStandardConfigMapper;
import lombok.RequiredArgsConstructor; import lombok.RequiredArgsConstructor;
import org.springframework.stereotype.Service; import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional; import org.springframework.transaction.annotation.Transactional;
import com.klp.domain.bo.CostStandardConfigBo; import com.klp.domain.bo.WmsCostStandardConfigBo;
import com.klp.domain.vo.CostStandardConfigVo;
import com.klp.domain.CostStandardConfig; import com.klp.service.IWmsCostStandardConfigService;
import com.klp.mapper.CostStandardConfigMapper;
import com.klp.service.ICostStandardConfigService;
import java.time.LocalDate; import java.time.LocalDate;
import java.util.Collection; import java.util.Collection;
@@ -27,15 +28,15 @@ import java.util.List;
*/ */
@RequiredArgsConstructor @RequiredArgsConstructor
@Service @Service
public class CostStandardConfigServiceImpl implements ICostStandardConfigService { public class WmsCostStandardConfigServiceImpl implements IWmsCostStandardConfigService {
private final CostStandardConfigMapper baseMapper; private final WmsCostStandardConfigMapper baseMapper;
/** /**
* 查询成本标准配置表 * 查询成本标准配置表
*/ */
@Override @Override
public CostStandardConfigVo queryById(Long configId) { public WmsCostStandardConfigVo queryById(Long configId) {
return baseMapper.selectVoById(configId); return baseMapper.selectVoById(configId);
} }
@@ -43,9 +44,9 @@ public class CostStandardConfigServiceImpl implements ICostStandardConfigService
* 查询成本标准配置表列表 * 查询成本标准配置表列表
*/ */
@Override @Override
public TableDataInfo<CostStandardConfigVo> queryPageList(CostStandardConfigBo bo, PageQuery pageQuery) { public TableDataInfo<WmsCostStandardConfigVo> queryPageList(WmsCostStandardConfigBo bo, PageQuery pageQuery) {
LambdaQueryWrapper<CostStandardConfig> lqw = buildQueryWrapper(bo); LambdaQueryWrapper<WmsCostStandardConfig> lqw = buildQueryWrapper(bo);
Page<CostStandardConfigVo> result = baseMapper.selectVoPage(pageQuery.build(), lqw); Page<WmsCostStandardConfigVo> result = baseMapper.selectVoPage(pageQuery.build(), lqw);
return TableDataInfo.build(result); return TableDataInfo.build(result);
} }
@@ -53,18 +54,18 @@ public class CostStandardConfigServiceImpl implements ICostStandardConfigService
* 查询成本标准配置表列表 * 查询成本标准配置表列表
*/ */
@Override @Override
public List<CostStandardConfigVo> queryList(CostStandardConfigBo bo) { public List<WmsCostStandardConfigVo> queryList(WmsCostStandardConfigBo bo) {
LambdaQueryWrapper<CostStandardConfig> lqw = buildQueryWrapper(bo); LambdaQueryWrapper<WmsCostStandardConfig> lqw = buildQueryWrapper(bo);
return baseMapper.selectVoList(lqw); return baseMapper.selectVoList(lqw);
} }
private LambdaQueryWrapper<CostStandardConfig> buildQueryWrapper(CostStandardConfigBo bo) { private LambdaQueryWrapper<WmsCostStandardConfig> buildQueryWrapper(WmsCostStandardConfigBo bo) {
LambdaQueryWrapper<CostStandardConfig> lqw = Wrappers.lambdaQuery(); LambdaQueryWrapper<WmsCostStandardConfig> lqw = Wrappers.lambdaQuery();
lqw.eq(bo.getConfigId() != null, CostStandardConfig::getConfigId, bo.getConfigId()); lqw.eq(bo.getConfigId() != null, WmsCostStandardConfig::getConfigId, bo.getConfigId());
lqw.eq(bo.getUnitCost() != null, CostStandardConfig::getUnitCost, bo.getUnitCost()); lqw.eq(bo.getUnitCost() != null, WmsCostStandardConfig::getUnitCost, bo.getUnitCost());
lqw.eq(bo.getEffectiveDate() != null, CostStandardConfig::getEffectiveDate, bo.getEffectiveDate()); lqw.eq(bo.getEffectiveDate() != null, WmsCostStandardConfig::getEffectiveDate, bo.getEffectiveDate());
lqw.eq(bo.getStatus() != null, CostStandardConfig::getStatus, bo.getStatus()); lqw.eq(bo.getStatus() != null, WmsCostStandardConfig::getStatus, bo.getStatus());
lqw.orderByDesc(CostStandardConfig::getEffectiveDate); lqw.orderByDesc(WmsCostStandardConfig::getEffectiveDate);
return lqw; return lqw;
} }
@@ -73,13 +74,13 @@ public class CostStandardConfigServiceImpl implements ICostStandardConfigService
*/ */
@Override @Override
@Transactional(rollbackFor = Exception.class) @Transactional(rollbackFor = Exception.class)
public Boolean insertByBo(CostStandardConfigBo bo) { public Boolean insertByBo(WmsCostStandardConfigBo bo) {
// 如果新标准立即生效需要将当前有效的标准标记为失效 // 如果新标准立即生效需要将当前有效的标准标记为失效
if (bo.getEffectiveDate() != null && !bo.getEffectiveDate().isAfter(LocalDate.now())) { if (bo.getEffectiveDate() != null && !bo.getEffectiveDate().isAfter(LocalDate.now())) {
// 将当前有效的标准标记为失效 // 将当前有效的标准标记为失效
CostStandardConfigVo current = queryCurrentEffective(); WmsCostStandardConfigVo current = queryCurrentEffective();
if (current != null) { if (current != null) {
CostStandardConfig update = new CostStandardConfig(); WmsCostStandardConfig update = new WmsCostStandardConfig();
update.setConfigId(current.getConfigId()); update.setConfigId(current.getConfigId());
update.setExpireDate(LocalDate.now().minusDays(1)); update.setExpireDate(LocalDate.now().minusDays(1));
update.setStatus(0); update.setStatus(0);
@@ -87,7 +88,7 @@ public class CostStandardConfigServiceImpl implements ICostStandardConfigService
} }
} }
CostStandardConfig add = BeanUtil.toBean(bo, CostStandardConfig.class); WmsCostStandardConfig add = BeanUtil.toBean(bo, WmsCostStandardConfig.class);
if (add.getStatus() == null) { if (add.getStatus() == null) {
add.setStatus(1); // 默认有效 add.setStatus(1); // 默认有效
} }
@@ -99,8 +100,8 @@ public class CostStandardConfigServiceImpl implements ICostStandardConfigService
* 修改成本标准配置表 * 修改成本标准配置表
*/ */
@Override @Override
public Boolean updateByBo(CostStandardConfigBo bo) { public Boolean updateByBo(WmsCostStandardConfigBo bo) {
CostStandardConfig update = BeanUtil.toBean(bo, CostStandardConfig.class); WmsCostStandardConfig update = BeanUtil.toBean(bo, WmsCostStandardConfig.class);
validEntityBeforeSave(update); validEntityBeforeSave(update);
return baseMapper.updateById(update) > 0; return baseMapper.updateById(update) > 0;
} }
@@ -108,7 +109,7 @@ public class CostStandardConfigServiceImpl implements ICostStandardConfigService
/** /**
* 保存前的数据校验 * 保存前的数据校验
*/ */
private void validEntityBeforeSave(CostStandardConfig entity) { private void validEntityBeforeSave(WmsCostStandardConfig entity) {
// TODO 做一些数据校验,如唯一约束 // TODO 做一些数据校验,如唯一约束
} }
@@ -127,7 +128,7 @@ public class CostStandardConfigServiceImpl implements ICostStandardConfigService
* 查询当前有效的成本标准 * 查询当前有效的成本标准
*/ */
@Override @Override
public CostStandardConfigVo queryCurrentEffective() { public WmsCostStandardConfigVo queryCurrentEffective() {
return baseMapper.selectCurrentEffective(); return baseMapper.selectCurrentEffective();
} }
@@ -135,7 +136,7 @@ public class CostStandardConfigServiceImpl implements ICostStandardConfigService
* 查询指定日期的有效成本标准 * 查询指定日期的有效成本标准
*/ */
@Override @Override
public CostStandardConfigVo queryEffectiveByDate(LocalDate date) { public WmsCostStandardConfigVo queryEffectiveByDate(LocalDate date) {
return baseMapper.selectEffectiveByDate(date); return baseMapper.selectEffectiveByDate(date);
} }
} }

View File

@@ -1,6 +1,6 @@
package com.klp.task; package com.klp.task;
import com.klp.service.ICostCoilDailyService; import com.klp.service.IWmsCostCoilDailyService;
import lombok.RequiredArgsConstructor; import lombok.RequiredArgsConstructor;
import lombok.extern.slf4j.Slf4j; import lombok.extern.slf4j.Slf4j;
import org.springframework.scheduling.annotation.Scheduled; import org.springframework.scheduling.annotation.Scheduled;
@@ -16,8 +16,8 @@ import java.time.LocalDate;
* 2. 按入场钢卷号维度生成前一日的日成本记录。 * 2. 按入场钢卷号维度生成前一日的日成本记录。
* *
* 说明: * 说明:
* - 具体的计算逻辑在 {@link ICostCoilDailyService#calculateDailyCost(LocalDate)} 和 * - 具体的计算逻辑在 {@link IWmsCostCoilDailyService#calculateDailyCost(LocalDate)} 和
* {@link ICostCoilDailyService#calculateDailyCostByEnterCoilNo(LocalDate)} 中实现。 * {@link IWmsCostCoilDailyService#calculateDailyCostByEnterCoilNo(LocalDate)} 中实现。
* - 当前任务只负责在固定时间触发这两个方法。 * - 当前任务只负责在固定时间触发这两个方法。
*/ */
@Slf4j @Slf4j
@@ -25,7 +25,7 @@ import java.time.LocalDate;
@Component @Component
public class CostCoilDailyTask { public class CostCoilDailyTask {
private final ICostCoilDailyService costCoilDailyService; private final IWmsCostCoilDailyService costCoilDailyService;
/** /**
* 每天凌晨 2:00 计算前一日钢卷日成本(按钢卷维度) * 每天凌晨 2:00 计算前一日钢卷日成本(按钢卷维度)

View File

@@ -2,9 +2,9 @@
<!DOCTYPE mapper <!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd"> "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.klp.mapper.CostCoilDailyMapper"> <mapper namespace="com.klp.mapper.WmsCostCoilDailyMapper">
<resultMap type="com.klp.domain.CostCoilDaily" id="CostCoilDailyResult"> <resultMap type="com.klp.domain.WmsCostCoilDaily" id="CostCoilDailyResult">
<result property="costId" column="cost_id"/> <result property="costId" column="cost_id"/>
<result property="coilId" column="coil_id"/> <result property="coilId" column="coil_id"/>
<result property="currentCoilNo" column="current_coil_no"/> <result property="currentCoilNo" column="current_coil_no"/>
@@ -20,7 +20,7 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
<result property="createTime" column="create_time"/> <result property="createTime" column="create_time"/>
</resultMap> </resultMap>
<resultMap type="com.klp.domain.vo.CostCoilDailyVo" id="CostCoilDailyVoResult"> <resultMap type="com.klp.domain.vo.WmsCostCoilDailyVo" id="CostCoilDailyVoResult">
<result property="costId" column="cost_id"/> <result property="costId" column="cost_id"/>
<result property="coilId" column="coil_id"/> <result property="coilId" column="coil_id"/>
<result property="currentCoilNo" column="current_coil_no"/> <result property="currentCoilNo" column="current_coil_no"/>
@@ -37,7 +37,7 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
</resultMap> </resultMap>
<!-- 自定义查询,关联库区名称 --> <!-- 自定义查询,关联库区名称 -->
<select id="selectVoPage" resultType="com.klp.domain.vo.CostCoilDailyVo"> <select id="selectVoPage" resultType="com.klp.domain.vo.WmsCostCoilDailyVo">
SELECT SELECT
ccd.cost_id, ccd.cost_id,
ccd.coil_id, ccd.coil_id,
@@ -52,7 +52,7 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
w.warehouse_name, w.warehouse_name,
ccd.item_type, ccd.item_type,
ccd.material_type ccd.material_type
FROM cost_coil_daily ccd FROM wms_cost_coil_daily ccd
LEFT JOIN wms_warehouse w ON ccd.warehouse_id = w.warehouse_id AND w.del_flag = 0 LEFT JOIN wms_warehouse w ON ccd.warehouse_id = w.warehouse_id AND w.del_flag = 0
${ew.customSqlSegment} ${ew.customSqlSegment}
</select> </select>
@@ -72,7 +72,7 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
w.warehouse_name, w.warehouse_name,
ccd.item_type, ccd.item_type,
ccd.material_type ccd.material_type
FROM cost_coil_daily ccd FROM wms_cost_coil_daily ccd
LEFT JOIN wms_warehouse w ON ccd.warehouse_id = w.warehouse_id AND w.del_flag = 0 LEFT JOIN wms_warehouse w ON ccd.warehouse_id = w.warehouse_id AND w.del_flag = 0
${ew.customSqlSegment} ${ew.customSqlSegment}
</select> </select>
@@ -92,7 +92,7 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
w.warehouse_name, w.warehouse_name,
ccd.item_type, ccd.item_type,
ccd.material_type ccd.material_type
FROM cost_coil_daily ccd FROM wms_cost_coil_daily ccd
LEFT JOIN wms_warehouse w ON ccd.warehouse_id = w.warehouse_id AND w.del_flag = 0 LEFT JOIN wms_warehouse w ON ccd.warehouse_id = w.warehouse_id AND w.del_flag = 0
WHERE ccd.cost_id = #{costId} WHERE ccd.cost_id = #{costId}
</select> </select>
@@ -102,13 +102,15 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
SELECT SELECT
COUNT(*) AS totalCoils, COUNT(*) AS totalCoils,
SUM(t.net_weight_ton) AS totalNetWeight, SUM(t.net_weight_ton) AS totalNetWeight,
SUM(t.gross_weight_ton) AS totalGrossWeight,
SUM(t.total_cost_amount) AS totalCost, SUM(t.total_cost_amount) AS totalCost,
AVG(t.storage_days) AS avgStorageDays, AVG(t.storage_days) AS avgStorageDays,
SUM(t.daily_cost_amount) AS totalDailyCost SUM(t.daily_cost_amount) AS totalDailyCost
FROM ( FROM (
SELECT SELECT
m.coil_id, m.coil_id,
IFNULL(m.net_weight, 0) / 1000 AS net_weight_ton, IFNULL(m.net_weight, 0) AS net_weight_ton,
IFNULL(m.gross_weight, 0) AS gross_weight_ton,
(DATEDIFF(CURDATE(), IFNULL(m.create_time, CURDATE())) + 1) AS storage_days, (DATEDIFF(CURDATE(), IFNULL(m.create_time, CURDATE())) + 1) AS storage_days,
CASE CASE
WHEN cs.unit_cost IS NULL THEN 0 WHEN cs.unit_cost IS NULL THEN 0
@@ -117,7 +119,7 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
WHEN IFNULL(m.gross_weight, 0) > 0 THEN m.gross_weight WHEN IFNULL(m.gross_weight, 0) > 0 THEN m.gross_weight
ELSE IFNULL(m.net_weight, 0) ELSE IFNULL(m.net_weight, 0)
END END
) / 1000 * cs.unit_cost ) * cs.unit_cost
END AS daily_cost_amount, END AS daily_cost_amount,
CASE CASE
WHEN cs.unit_cost IS NULL THEN 0 WHEN cs.unit_cost IS NULL THEN 0
@@ -126,10 +128,10 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
WHEN IFNULL(m.gross_weight, 0) > 0 THEN m.gross_weight WHEN IFNULL(m.gross_weight, 0) > 0 THEN m.gross_weight
ELSE IFNULL(m.net_weight, 0) ELSE IFNULL(m.net_weight, 0)
END END
) / 1000 * cs.unit_cost * (DATEDIFF(CURDATE(), IFNULL(m.create_time, CURDATE())) + 1) ) * cs.unit_cost * (DATEDIFF(CURDATE(), IFNULL(m.create_time, CURDATE())) + 1)
END AS total_cost_amount END AS total_cost_amount
FROM wms_material_coil m FROM wms_material_coil m
LEFT JOIN cost_standard_config cs LEFT JOIN wms_cost_standard_config cs
ON cs.status = 1 ON cs.status = 1
AND DATE(m.create_time) >= cs.effective_date AND DATE(m.create_time) >= cs.effective_date
AND (cs.expire_date IS NULL OR DATE(m.create_time) &lt;= cs.expire_date) AND (cs.expire_date IS NULL OR DATE(m.create_time) &lt;= cs.expire_date)
@@ -156,12 +158,14 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
COUNT(*) AS coilCount, COUNT(*) AS coilCount,
SUM(t.total_cost_amount) AS totalCost, SUM(t.total_cost_amount) AS totalCost,
AVG(t.storage_days) AS avgStorageDays, AVG(t.storage_days) AS avgStorageDays,
SUM(t.net_weight_ton) AS totalNetWeight SUM(t.net_weight_ton) AS totalNetWeight,
SUM(t.gross_weight_ton) AS totalGrossWeight
FROM ( FROM (
SELECT SELECT
m.coil_id, m.coil_id,
m.warehouse_id, m.warehouse_id,
IFNULL(m.net_weight, 0) / 1000 AS net_weight_ton, IFNULL(m.net_weight, 0) AS net_weight_ton,
IFNULL(m.gross_weight, 0) AS gross_weight_ton,
(DATEDIFF(CURDATE(), IFNULL(m.create_time, CURDATE())) + 1) AS storage_days, (DATEDIFF(CURDATE(), IFNULL(m.create_time, CURDATE())) + 1) AS storage_days,
CASE CASE
WHEN cs.unit_cost IS NULL THEN 0 WHEN cs.unit_cost IS NULL THEN 0
@@ -170,10 +174,10 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
WHEN IFNULL(m.gross_weight, 0) > 0 THEN m.gross_weight WHEN IFNULL(m.gross_weight, 0) > 0 THEN m.gross_weight
ELSE IFNULL(m.net_weight, 0) ELSE IFNULL(m.net_weight, 0)
END END
) / 1000 * cs.unit_cost * (DATEDIFF(CURDATE(), IFNULL(m.create_time, CURDATE())) + 1) ) * cs.unit_cost * (DATEDIFF(CURDATE(), IFNULL(m.create_time, CURDATE())) + 1)
END AS total_cost_amount END AS total_cost_amount
FROM wms_material_coil m FROM wms_material_coil m
LEFT JOIN cost_standard_config cs LEFT JOIN wms_cost_standard_config cs
ON cs.status = 1 ON cs.status = 1
AND DATE(m.create_time) >= cs.effective_date AND DATE(m.create_time) >= cs.effective_date
AND (cs.expire_date IS NULL OR DATE(m.create_time) &lt;= cs.expire_date) AND (cs.expire_date IS NULL OR DATE(m.create_time) &lt;= cs.expire_date)
@@ -193,12 +197,14 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
COUNT(*) AS coilCount, COUNT(*) AS coilCount,
SUM(t.total_cost_amount) AS totalCost, SUM(t.total_cost_amount) AS totalCost,
AVG(t.storage_days) AS avgStorageDays, AVG(t.storage_days) AS avgStorageDays,
SUM(t.net_weight_ton) AS totalNetWeight SUM(t.net_weight_ton) AS totalNetWeight,
SUM(t.gross_weight_ton) AS totalGrossWeight
FROM ( FROM (
SELECT SELECT
m.coil_id, m.coil_id,
m.item_type, m.item_type,
IFNULL(m.net_weight, 0) / 1000 AS net_weight_ton, IFNULL(m.net_weight, 0) AS net_weight_ton,
IFNULL(m.gross_weight, 0) AS gross_weight_ton,
(DATEDIFF(CURDATE(), IFNULL(m.create_time, CURDATE())) + 1) AS storage_days, (DATEDIFF(CURDATE(), IFNULL(m.create_time, CURDATE())) + 1) AS storage_days,
CASE CASE
WHEN cs.unit_cost IS NULL THEN 0 WHEN cs.unit_cost IS NULL THEN 0
@@ -207,10 +213,10 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
WHEN IFNULL(m.gross_weight, 0) > 0 THEN m.gross_weight WHEN IFNULL(m.gross_weight, 0) > 0 THEN m.gross_weight
ELSE IFNULL(m.net_weight, 0) ELSE IFNULL(m.net_weight, 0)
END END
) / 1000 * cs.unit_cost * (DATEDIFF(CURDATE(), IFNULL(m.create_time, CURDATE())) + 1) ) * cs.unit_cost * (DATEDIFF(CURDATE(), IFNULL(m.create_time, CURDATE())) + 1)
END AS total_cost_amount END AS total_cost_amount
FROM wms_material_coil m FROM wms_material_coil m
LEFT JOIN cost_standard_config cs LEFT JOIN wms_cost_standard_config cs
ON cs.status = 1 ON cs.status = 1
AND DATE(m.create_time) >= cs.effective_date AND DATE(m.create_time) >= cs.effective_date
AND (cs.expire_date IS NULL OR DATE(m.create_time) &lt;= cs.expire_date) AND (cs.expire_date IS NULL OR DATE(m.create_time) &lt;= cs.expire_date)
@@ -225,7 +231,7 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
<!-- 检查指定日期和钢卷的成本记录是否存在 --> <!-- 检查指定日期和钢卷的成本记录是否存在 -->
<select id="countByCoilIdAndDate" resultType="int"> <select id="countByCoilIdAndDate" resultType="int">
SELECT COUNT(1) SELECT COUNT(1)
FROM cost_coil_daily FROM wms_cost_coil_daily
WHERE coil_id = #{coilId} WHERE coil_id = #{coilId}
AND calc_date = #{calcDate} AND calc_date = #{calcDate}
</select> </select>
@@ -241,7 +247,7 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
SUM(ccd.net_weight) AS totalNetWeight, SUM(ccd.net_weight) AS totalNetWeight,
AVG(ccd.storage_days) AS avgStorageDays, AVG(ccd.storage_days) AS avgStorageDays,
MAX(ccd.calc_date) AS lastCalcDate MAX(ccd.calc_date) AS lastCalcDate
FROM cost_coil_daily ccd FROM wms_cost_coil_daily ccd
INNER JOIN wms_material_coil mc ON ccd.coil_id = mc.coil_id INNER JOIN wms_material_coil mc ON ccd.coil_id = mc.coil_id
WHERE ccd.calc_date BETWEEN #{startDate} AND #{endDate} WHERE ccd.calc_date BETWEEN #{startDate} AND #{endDate}
AND mc.data_type = 1 AND mc.data_type = 1
@@ -261,24 +267,25 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
SUM(t.gross_weight_ton) AS totalGrossWeight, SUM(t.gross_weight_ton) AS totalGrossWeight,
SUM(t.cost_amount) AS totalCost, SUM(t.cost_amount) AS totalCost,
AVG(t.storage_days) AS avgStorageDays, AVG(t.storage_days) AS avgStorageDays,
MAX(t.storage_days) AS maxStorageDays MAX(t.storage_days) AS maxStorageDays,
MAX(CASE WHEN IFNULL(t.net_weight_ton, 0) = 0 THEN 1 ELSE 0 END) AS hasNetWeightZero
FROM ( FROM (
SELECT SELECT
m.enter_coil_no, m.enter_coil_no,
IFNULL(m.net_weight, 0) / 1000 AS net_weight_ton, IFNULL(m.net_weight, 0) AS net_weight_ton,
IFNULL(m.gross_weight, 0) / 1000 AS gross_weight_ton, IFNULL(m.gross_weight, 0) AS gross_weight_ton,
CASE CASE
WHEN cs.unit_cost IS NULL THEN 0 WHEN cs.unit_cost IS NULL THEN 0
ELSE ( ELSE (
CASE CASE
WHEN IFNULL(m.gross_weight, 0) > 0 THEN m.gross_weight WHEN IFNULL(m.net_weight, 0) = 0 AND IFNULL(m.gross_weight, 0) > 0 THEN m.gross_weight
ELSE IFNULL(m.net_weight, 0) ELSE IFNULL(m.net_weight, 0)
END END
) / 1000 * cs.unit_cost * (DATEDIFF(CURDATE(), IFNULL(m.create_time, CURDATE())) + 1) ) * cs.unit_cost * (DATEDIFF(CURDATE(), IFNULL(m.create_time, CURDATE())) + 1)
END AS cost_amount, END AS cost_amount,
(DATEDIFF(CURDATE(), IFNULL(m.create_time, CURDATE())) + 1) AS storage_days (DATEDIFF(CURDATE(), IFNULL(m.create_time, CURDATE())) + 1) AS storage_days
FROM wms_material_coil m FROM wms_material_coil m
LEFT JOIN cost_standard_config cs LEFT JOIN wms_cost_standard_config cs
ON cs.status = 1 ON cs.status = 1
AND DATE(m.create_time) >= cs.effective_date AND DATE(m.create_time) >= cs.effective_date
AND (cs.expire_date IS NULL OR DATE(m.create_time) &lt;= cs.expire_date) AND (cs.expire_date IS NULL OR DATE(m.create_time) &lt;= cs.expire_date)
@@ -320,8 +327,8 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
AVG(t.storage_days) AS avgStorageDays AVG(t.storage_days) AS avgStorageDays
FROM ( FROM (
SELECT SELECT
IFNULL(m.net_weight, 0) / 1000 AS net_weight_ton, IFNULL(m.net_weight, 0) AS net_weight_ton,
IFNULL(m.gross_weight, 0) / 1000 AS gross_weight_ton, IFNULL(m.gross_weight, 0) AS gross_weight_ton,
CASE CASE
WHEN cs.unit_cost IS NULL THEN 0 WHEN cs.unit_cost IS NULL THEN 0
ELSE ( ELSE (
@@ -329,11 +336,11 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
WHEN IFNULL(m.gross_weight, 0) > 0 THEN m.gross_weight WHEN IFNULL(m.gross_weight, 0) > 0 THEN m.gross_weight
ELSE IFNULL(m.net_weight, 0) ELSE IFNULL(m.net_weight, 0)
END END
) / 1000 * cs.unit_cost * (DATEDIFF(CURDATE(), IFNULL(m.create_time, CURDATE())) + 1) ) * cs.unit_cost * (DATEDIFF(CURDATE(), IFNULL(m.create_time, CURDATE())) + 1)
END AS cost_amount, END AS cost_amount,
(DATEDIFF(CURDATE(), IFNULL(m.create_time, CURDATE())) + 1) AS storage_days (DATEDIFF(CURDATE(), IFNULL(m.create_time, CURDATE())) + 1) AS storage_days
FROM wms_material_coil m FROM wms_material_coil m
LEFT JOIN cost_standard_config cs LEFT JOIN wms_cost_standard_config cs
ON cs.status = 1 ON cs.status = 1
AND DATE(m.create_time) >= cs.effective_date AND DATE(m.create_time) >= cs.effective_date
AND (cs.expire_date IS NULL OR DATE(m.create_time) &lt;= cs.expire_date) AND (cs.expire_date IS NULL OR DATE(m.create_time) &lt;= cs.expire_date)
@@ -355,8 +362,8 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
SUM(t.cost_amount) AS totalCost SUM(t.cost_amount) AS totalCost
FROM ( FROM (
SELECT SELECT
IFNULL(m.net_weight, 0) / 1000 AS net_weight_ton, IFNULL(m.net_weight, 0) AS net_weight_ton,
IFNULL(m.gross_weight, 0) / 1000 AS gross_weight_ton, IFNULL(m.gross_weight, 0) AS gross_weight_ton,
(DATEDIFF(CURDATE(), IFNULL(m.create_time, CURDATE())) + 1) AS storage_days, (DATEDIFF(CURDATE(), IFNULL(m.create_time, CURDATE())) + 1) AS storage_days,
CASE CASE
WHEN cs.unit_cost IS NULL THEN 0 WHEN cs.unit_cost IS NULL THEN 0
@@ -365,10 +372,10 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
WHEN IFNULL(m.gross_weight, 0) > 0 THEN m.gross_weight WHEN IFNULL(m.gross_weight, 0) > 0 THEN m.gross_weight
ELSE IFNULL(m.net_weight, 0) ELSE IFNULL(m.net_weight, 0)
END END
) / 1000 * cs.unit_cost * (DATEDIFF(CURDATE(), IFNULL(m.create_time, CURDATE())) + 1) ) * cs.unit_cost * (DATEDIFF(CURDATE(), IFNULL(m.create_time, CURDATE())) + 1)
END AS cost_amount END AS cost_amount
FROM wms_material_coil m FROM wms_material_coil m
LEFT JOIN cost_standard_config cs LEFT JOIN wms_cost_standard_config cs
ON cs.status = 1 ON cs.status = 1
AND DATE(m.create_time) >= cs.effective_date AND DATE(m.create_time) >= cs.effective_date
AND (cs.expire_date IS NULL OR DATE(m.create_time) &lt;= cs.expire_date) AND (cs.expire_date IS NULL OR DATE(m.create_time) &lt;= cs.expire_date)
@@ -378,14 +385,15 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
) t ) t
</select> </select>
<!-- 成本趋势(按日统计 cost_coil_daily --> <!-- 成本趋势(按日统计 wms_cost_coil_daily -->
<select id="selectCostTrend" resultType="java.util.HashMap"> <select id="selectCostTrend" resultType="java.util.HashMap">
SELECT SELECT
ccd.calc_date AS date, ccd.calc_date AS date,
SUM(ccd.total_cost) AS totalCost, SUM(ccd.total_cost) AS totalCost,
SUM(ccd.net_weight) AS totalNetWeight, SUM(ccd.net_weight) AS totalNetWeight,
SUM(ccd.daily_cost) AS totalDailyCost SUM(ccd.daily_cost) AS totalDailyCost,
FROM cost_coil_daily ccd COUNT(*) AS coilCount
FROM wms_cost_coil_daily ccd
WHERE 1 = 1 WHERE 1 = 1
<if test="startDate != null"> <if test="startDate != null">
AND ccd.calc_date &gt;= #{startDate} AND ccd.calc_date &gt;= #{startDate}
@@ -403,8 +411,8 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
m.enter_coil_no, m.enter_coil_no,
m.coil_id, m.coil_id,
m.current_coil_no, m.current_coil_no,
IFNULL(m.net_weight, 0) / 1000 AS net_weight_ton, IFNULL(m.net_weight, 0) AS net_weight_ton,
IFNULL(m.gross_weight, 0) / 1000 AS gross_weight_ton, IFNULL(m.gross_weight, 0) AS gross_weight_ton,
CASE CASE
WHEN IFNULL(m.gross_weight, 0) > 0 THEN 'gross' WHEN IFNULL(m.gross_weight, 0) > 0 THEN 'gross'
ELSE 'net' ELSE 'net'
@@ -412,7 +420,7 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
CASE CASE
WHEN IFNULL(m.gross_weight, 0) > 0 THEN IFNULL(m.gross_weight, 0) WHEN IFNULL(m.gross_weight, 0) > 0 THEN IFNULL(m.gross_weight, 0)
ELSE IFNULL(m.net_weight, 0) ELSE IFNULL(m.net_weight, 0)
END / 1000 AS charge_weight_ton, END AS charge_weight_ton,
DATE(m.create_time) AS start_date, DATE(m.create_time) AS start_date,
CASE CASE
WHEN m.export_time IS NOT NULL THEN DATE_SUB(DATE(m.export_time), INTERVAL 1 DAY) WHEN m.export_time IS NOT NULL THEN DATE_SUB(DATE(m.export_time), INTERVAL 1 DAY)
@@ -427,7 +435,7 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
m.warehouse_id, m.warehouse_id,
COALESCE(w.warehouse_name, '-') AS warehouse_name COALESCE(w.warehouse_name, '-') AS warehouse_name
FROM wms_material_coil m FROM wms_material_coil m
LEFT JOIN cost_standard_config cs LEFT JOIN wms_cost_standard_config cs
ON cs.status = 1 ON cs.status = 1
AND DATE(m.create_time) >= cs.effective_date AND DATE(m.create_time) >= cs.effective_date
AND (cs.expire_date IS NULL OR DATE(m.create_time) &lt;= cs.expire_date) AND (cs.expire_date IS NULL OR DATE(m.create_time) &lt;= cs.expire_date)
@@ -515,7 +523,7 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
<!-- 删除指定日期的成本记录 --> <!-- 删除指定日期的成本记录 -->
<delete id="deleteByCalcDate"> <delete id="deleteByCalcDate">
DELETE FROM cost_coil_daily DELETE FROM wms_cost_coil_daily
WHERE calc_date = #{calcDate} WHERE calc_date = #{calcDate}
</delete> </delete>

View File

@@ -2,9 +2,9 @@
<!DOCTYPE mapper <!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd"> "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.klp.mapper.CostStandardConfigMapper"> <mapper namespace="com.klp.mapper.WmsCostStandardConfigMapper">
<resultMap type="com.klp.domain.CostStandardConfig" id="CostStandardConfigResult"> <resultMap type="com.klp.domain.WmsCostStandardConfig" id="CostStandardConfigResult">
<result property="configId" column="config_id"/> <result property="configId" column="config_id"/>
<result property="unitCost" column="unit_cost"/> <result property="unitCost" column="unit_cost"/>
<result property="effectiveDate" column="effective_date"/> <result property="effectiveDate" column="effective_date"/>
@@ -18,7 +18,7 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
<result property="updateBy" column="update_by"/> <result property="updateBy" column="update_by"/>
</resultMap> </resultMap>
<resultMap type="com.klp.domain.vo.CostStandardConfigVo" id="CostStandardConfigVoResult"> <resultMap type="com.klp.domain.vo.WmsCostStandardConfigVo" id="CostStandardConfigVoResult">
<result property="configId" column="config_id"/> <result property="configId" column="config_id"/>
<result property="unitCost" column="unit_cost"/> <result property="unitCost" column="unit_cost"/>
<result property="effectiveDate" column="effective_date"/> <result property="effectiveDate" column="effective_date"/>
@@ -34,7 +34,7 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
<!-- 查询指定日期的有效成本标准 --> <!-- 查询指定日期的有效成本标准 -->
<select id="selectEffectiveByDate" resultMap="CostStandardConfigVoResult"> <select id="selectEffectiveByDate" resultMap="CostStandardConfigVoResult">
SELECT * SELECT *
FROM cost_standard_config FROM wms_cost_standard_config
WHERE del_flag = 0 WHERE del_flag = 0
AND status = 1 AND status = 1
AND effective_date &lt;= #{date} AND effective_date &lt;= #{date}
@@ -46,7 +46,7 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
<!-- 查询当前有效的成本标准 --> <!-- 查询当前有效的成本标准 -->
<select id="selectCurrentEffective" resultMap="CostStandardConfigVoResult"> <select id="selectCurrentEffective" resultMap="CostStandardConfigVoResult">
SELECT * SELECT *
FROM cost_standard_config FROM wms_cost_standard_config
WHERE del_flag = 0 WHERE del_flag = 0
AND status = 1 AND status = 1
AND effective_date &lt;= CURDATE() AND effective_date &lt;= CURDATE()