原材料库存记录

This commit is contained in:
2026-05-15 17:34:31 +08:00
parent b496a03190
commit 530a0f13e7
8 changed files with 384 additions and 1327 deletions

View File

@@ -0,0 +1,150 @@
package org.jeecg.modules.xslmes.controller;
import com.baomidou.mybatisplus.core.metadata.IPage;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import io.swagger.v3.oas.annotations.Operation;
import io.swagger.v3.oas.annotations.tags.Tag;
import jakarta.servlet.http.HttpServletRequest;
import java.util.ArrayList;
import java.util.List;
import lombok.extern.slf4j.Slf4j;
import org.apache.commons.lang3.StringUtils;
import org.apache.shiro.SecurityUtils;
import org.apache.shiro.authz.annotation.RequiresPermissions;
import org.jeecg.common.api.vo.Result;
import org.jeecg.common.system.vo.LoginUser;
import org.jeecg.common.util.oConvertUtils;
import org.jeecg.modules.xslmes.entity.MesXslRawMaterialSummary;
import org.jeecgframework.poi.excel.def.NormalExcelConstants;
import org.jeecgframework.poi.excel.entity.ExportParams;
import org.jeecgframework.poi.excel.entity.enmus.ExcelType;
import org.jeecgframework.poi.excel.view.JeecgEntityExcelView;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;
import org.springframework.web.servlet.ModelAndView;
/**
* 原材料汇总
*/
@Tag(name = "原材料汇总")
@RestController
@RequestMapping("/xslmes/mesXslRawMaterialSummary")
@Slf4j
public class MesXslRawMaterialSummaryController {
@Autowired
private JdbcTemplate jdbcTemplate;
@Operation(summary = "原材料汇总-分页列表查询")
@GetMapping(value = "/list")
public Result<IPage<MesXslRawMaterialSummary>> queryPageList(
MesXslRawMaterialSummary query,
@RequestParam(name = "pageNo", defaultValue = "1") Integer pageNo,
@RequestParam(name = "pageSize", defaultValue = "10") Integer pageSize) {
List<Object> params = new ArrayList<>();
String groupedSql = buildGroupedSql(query, params);
String countSql = "SELECT COUNT(1) FROM (" + groupedSql + ") t";
Long total = jdbcTemplate.queryForObject(countSql, Long.class, params.toArray());
long totalCount = total == null ? 0L : total;
int offset = Math.max((pageNo - 1) * pageSize, 0);
String pageSql = groupedSql + " ORDER BY warehouseName, materialName LIMIT ? OFFSET ?";
List<Object> pageParams = new ArrayList<>(params);
pageParams.add(pageSize);
pageParams.add(offset);
List<MesXslRawMaterialSummary> rows = queryRows(pageSql, pageParams);
Page<MesXslRawMaterialSummary> page = new Page<>(pageNo, pageSize, totalCount);
page.setRecords(rows);
return Result.OK(page);
}
@RequiresPermissions("xslmes:mes_xsl_raw_material_summary:exportXls")
@RequestMapping(value = "/exportXls")
public ModelAndView exportXls(HttpServletRequest request, MesXslRawMaterialSummary query) {
List<Object> params = new ArrayList<>();
String groupedSql = buildGroupedSql(query, params) + " ORDER BY warehouseName, materialName";
List<MesXslRawMaterialSummary> exportList = queryRows(groupedSql, params);
LoginUser sysUser = (LoginUser) SecurityUtils.getSubject().getPrincipal();
ModelAndView mv = new ModelAndView(new JeecgEntityExcelView());
mv.addObject(NormalExcelConstants.FILE_NAME, "原材料汇总");
mv.addObject(NormalExcelConstants.CLASS, MesXslRawMaterialSummary.class);
mv.addObject(
NormalExcelConstants.PARAMS,
new ExportParams("原材料汇总报表", "导出人:" + (sysUser == null ? "admin" : sysUser.getRealname()), "原材料汇总", ExcelType.XSSF));
mv.addObject(NormalExcelConstants.DATA_LIST, exportList);
String exportFields = request.getParameter(NormalExcelConstants.EXPORT_FIELDS);
if (oConvertUtils.isNotEmpty(exportFields)) {
mv.addObject(NormalExcelConstants.EXPORT_FIELDS, exportFields);
}
return mv;
}
private String buildGroupedSql(MesXslRawMaterialSummary query, List<Object> params) {
String warehouseExpr = "COALESCE(NULLIF(TRIM(i.warehouse_name),''), TRIM(w.warehouse_name))";
String materialNameExpr = "COALESCE(NULLIF(TRIM(i.material_name),''), TRIM(m.material_name))";
String materialCodeExpr = "COALESCE(NULLIF(TRIM(i.material_code),''), TRIM(m.material_code))";
StringBuilder sql = new StringBuilder();
sql.append("SELECT ")
.append(warehouseExpr).append(" AS warehouseName, ")
.append(materialNameExpr).append(" AS materialName, ")
.append(materialCodeExpr).append(" AS materialCode, ")
.append("SUM(COALESCE(i.total_packages,0)) AS totalPackages, ")
.append("SUM(COALESCE(i.total_weight,0)) AS totalWeight ")
.append("FROM mes_xsl_raw_material_inventory i ")
.append("LEFT JOIN mes_xsl_warehouse w ON w.id = i.warehouse_id ")
.append("AND (w.del_flag = 0 OR w.del_flag IS NULL) ")
.append("LEFT JOIN mes_mixer_material m ON m.id = i.material_id ")
.append("AND (m.del_flag = 0 OR m.del_flag IS NULL) ")
.append("WHERE (i.del_flag = 0 OR i.del_flag IS NULL) ");
if (query != null && StringUtils.isNotBlank(query.getWarehouseName())) {
sql.append("AND ").append(warehouseExpr).append(" LIKE ? ");
params.add("%" + query.getWarehouseName().trim() + "%");
}
if (query != null && StringUtils.isNotBlank(query.getMaterialName())) {
sql.append("AND ").append(materialNameExpr).append(" LIKE ? ");
params.add("%" + query.getMaterialName().trim() + "%");
}
if (query != null && StringUtils.isNotBlank(query.getMaterialCode())) {
sql.append("AND ").append(materialCodeExpr).append(" LIKE ? ");
params.add("%" + query.getMaterialCode().trim() + "%");
}
sql.append("GROUP BY ")
.append(warehouseExpr).append(", ")
.append(materialNameExpr).append(", ")
.append(materialCodeExpr);
return sql.toString();
}
private List<MesXslRawMaterialSummary> queryRows(String sql, List<Object> params) {
return jdbcTemplate.query(
sql,
rs -> {
List<MesXslRawMaterialSummary> list = new ArrayList<>();
int seq = 1;
while (rs.next()) {
MesXslRawMaterialSummary row = new MesXslRawMaterialSummary();
row.setWarehouseName(trim(rs.getString("warehouseName")));
row.setMaterialName(trim(rs.getString("materialName")));
row.setMaterialCode(trim(rs.getString("materialCode")));
row.setTotalPackages(rs.getBigDecimal("totalPackages"));
row.setTotalWeight(rs.getBigDecimal("totalWeight"));
row.setId(row.getWarehouseName() + "_" + row.getMaterialCode() + "_" + seq++);
list.add(row);
}
return list;
},
params.toArray());
}
private String trim(String v) {
return v == null ? "" : v.trim();
}
}

View File

@@ -0,0 +1,40 @@
package org.jeecg.modules.xslmes.entity;
import io.swagger.v3.oas.annotations.media.Schema;
import java.io.Serializable;
import java.math.BigDecimal;
import lombok.Data;
import org.jeecgframework.poi.excel.annotation.Excel;
/**
* 原材料汇总(按仓库+物料)
*/
@Data
@Schema(description = "原材料汇总")
public class MesXslRawMaterialSummary implements Serializable {
private static final long serialVersionUID = 1L;
@Schema(description = "主键")
private String id;
@Excel(name = "所在仓库", width = 20)
@Schema(description = "所在仓库")
private String warehouseName;
@Excel(name = "物料名称", width = 20)
@Schema(description = "物料名称")
private String materialName;
@Excel(name = "物料编码", width = 20)
@Schema(description = "物料编码")
private String materialCode;
@Excel(name = "总包数", width = 15)
@Schema(description = "总包数")
private BigDecimal totalPackages;
@Excel(name = "总重量", width = 15)
@Schema(description = "总重量")
private BigDecimal totalWeight;
}