This commit is contained in:
2025-11-11 22:03:30 +08:00
parent 685bb0cebd
commit ff88c2c04a
947 changed files with 122829 additions and 0 deletions

View File

@@ -0,0 +1,68 @@
package com.klp.pocket.controller;
import com.klp.common.core.controller.BaseController;
import com.klp.common.core.domain.PageQuery;
import com.klp.common.core.domain.R;
import com.klp.common.core.page.TableDataInfo;
import com.klp.pocket.domain.Klptcm1ProPlantStateCurrent;
import com.klp.pocket.service.IKlptcm1ProPlantStateCurrentService;
import org.springframework.web.bind.annotation.*;
import javax.annotation.Resource;
import java.util.List;
import java.util.Date;
import java.math.BigDecimal;
import org.springframework.format.annotation.DateTimeFormat;
@RestController
@RequestMapping("/pocket/proPlantStateCurrent")
public class Klptcm1ProPlantStateCurrentController extends BaseController {
@Resource
private IKlptcm1ProPlantStateCurrentService klptcm1ProPlantStateCurrentService;
/**
* 查询所有数据
*/
@GetMapping("/selectAll")
public TableDataInfo<Klptcm1ProPlantStateCurrent> selectAll(PageQuery pageQuery) {
return klptcm1ProPlantStateCurrentService.selectAll(pageQuery);
}
/**
* 查询单条(按 INSDATE + TYPE
*/
@GetMapping("/one")
public R<Klptcm1ProPlantStateCurrent> getOne(
@RequestParam("type") BigDecimal type,
@RequestParam("insdate") @DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss") Date insdate) {
return R.ok(klptcm1ProPlantStateCurrentService.selectOne(insdate, type));
}
/**
* 新增一条 current 记录
*/
@PostMapping
public R<Void> add(@RequestBody Klptcm1ProPlantStateCurrent entity) {
return toAjax(klptcm1ProPlantStateCurrentService.insert(entity));
}
/**
* 修改一条 current 记录(依据 INSDATE + TYPE
*/
@PutMapping
public R<Void> edit(@RequestBody Klptcm1ProPlantStateCurrent entity) {
return toAjax(klptcm1ProPlantStateCurrentService.updateByKey(entity));
}
/**
* 删除一条 current 记录(按 INSDATE + TYPE
*/
@DeleteMapping
public R<Void> remove(
@RequestParam("type") BigDecimal type,
@RequestParam("insdate") @DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss") Date insdate) {
return toAjax(klptcm1ProPlantStateCurrentService.deleteByKey(insdate, type));
}
}

View File

@@ -0,0 +1,88 @@
package com.klp.pocket.controller;
import com.klp.common.annotation.Log;
import com.klp.common.annotation.RepeatSubmit;
import com.klp.common.core.domain.R;
import com.klp.common.core.validate.AddGroup;
import com.klp.common.core.validate.EditGroup;
import com.klp.common.enums.BusinessType;
import lombok.RequiredArgsConstructor;
import org.springframework.web.bind.annotation.*;
import org.springframework.validation.annotation.Validated;
import com.klp.common.core.controller.BaseController;
import com.klp.common.core.domain.PageQuery;
import com.klp.pocket.domain.vo.Klptcm1ProPlantStateHistoryVo;
import com.klp.pocket.domain.bo.Klptcm1ProPlantStateHistoryBo;
import com.klp.pocket.service.IKlptcm1ProPlantStateHistoryService;
import com.klp.common.core.page.TableDataInfo;
import javax.validation.constraints.NotEmpty;
import javax.validation.constraints.NotNull;
import java.util.Arrays;
import java.util.Date;
/**
* 历史
*
* @author klp
* @date 2025-10-27
*/
@Validated
@RequiredArgsConstructor
@RestController
@RequestMapping("/pocket/proPlantStateHistory")
public class Klptcm1ProPlantStateHistoryController extends BaseController {
private final IKlptcm1ProPlantStateHistoryService iKlptcm1ProPlantStateHistoryService;
/**
* 查询历史列表
*/
@GetMapping("/list")
public TableDataInfo<Klptcm1ProPlantStateHistoryVo> list(Klptcm1ProPlantStateHistoryBo bo, PageQuery pageQuery) {
return iKlptcm1ProPlantStateHistoryService.queryPageList(bo, pageQuery);
}
/**
* 获取历史详细信息
*
* @param INSDATE 主键
*/
@GetMapping("/{INSDATE}")
public R<Klptcm1ProPlantStateHistoryVo> getInfo(@NotNull(message = "主键不能为空")
@PathVariable Date INSDATE) {
return R.ok(iKlptcm1ProPlantStateHistoryService.queryById(INSDATE));
}
/**
* 新增历史
*/
@Log(title = "历史", businessType = BusinessType.INSERT)
@RepeatSubmit()
@PostMapping()
public R<Void> add(@Validated(AddGroup.class) @RequestBody Klptcm1ProPlantStateHistoryBo bo) {
return toAjax(iKlptcm1ProPlantStateHistoryService.insertByBo(bo));
}
/**
* 修改历史
*/
@Log(title = "历史", businessType = BusinessType.UPDATE)
@RepeatSubmit()
@PutMapping()
public R<Void> edit(@Validated(EditGroup.class) @RequestBody Klptcm1ProPlantStateHistoryBo bo) {
return toAjax(iKlptcm1ProPlantStateHistoryService.updateByBo(bo));
}
/**
* 删除历史
*
* @param INSDATEs 主键串
*/
@Log(title = "历史", businessType = BusinessType.DELETE)
@DeleteMapping("/{INSDATEs}")
public R<Void> remove(@NotEmpty(message = "主键不能为空")
@PathVariable Date[] INSDATEs) {
return toAjax(iKlptcm1ProPlantStateHistoryService.deleteWithValidByIds(Arrays.asList(INSDATEs), true));
}
}

View File

@@ -0,0 +1,87 @@
package com.klp.pocket.controller;
import com.klp.common.annotation.Log;
import com.klp.common.annotation.RepeatSubmit;
import com.klp.common.core.domain.R;
import com.klp.common.core.validate.AddGroup;
import com.klp.common.core.validate.EditGroup;
import com.klp.common.enums.BusinessType;
import lombok.RequiredArgsConstructor;
import org.springframework.web.bind.annotation.*;
import org.springframework.validation.annotation.Validated;
import com.klp.common.core.controller.BaseController;
import com.klp.common.core.domain.PageQuery;
import com.klp.pocket.domain.vo.Klptcm1ProStoppageVo;
import com.klp.pocket.domain.bo.Klptcm1ProStoppageBo;
import com.klp.pocket.service.IKlptcm1ProStoppageService;
import com.klp.common.core.page.TableDataInfo;
import javax.validation.constraints.NotEmpty;
import javax.validation.constraints.NotNull;
import java.util.Arrays;
/**
* 停机
*
* @author klp
* @date 2025-10-27
*/
@Validated
@RequiredArgsConstructor
@RestController
@RequestMapping("/pocket/proStoppage")
public class Klptcm1ProStoppageController extends BaseController {
private final IKlptcm1ProStoppageService iKlptcm1ProStoppageService;
/**
* 查询停机列表
*/
@GetMapping("/list")
public TableDataInfo<Klptcm1ProStoppageVo> list(Klptcm1ProStoppageBo bo, PageQuery pageQuery) {
return iKlptcm1ProStoppageService.queryPageList(bo, pageQuery);
}
/**
* 获取停机详细信息
*
* @param STOPID 主键
*/
@GetMapping("/{STOPID}")
public R<Klptcm1ProStoppageVo> getInfo(@NotNull(message = "主键不能为空")
@PathVariable Long STOPID) {
return R.ok(iKlptcm1ProStoppageService.queryById(STOPID));
}
/**
* 新增停机
*/
@Log(title = "停机", businessType = BusinessType.INSERT)
@RepeatSubmit()
@PostMapping()
public R<Void> add(@Validated(AddGroup.class) @RequestBody Klptcm1ProStoppageBo bo) {
return toAjax(iKlptcm1ProStoppageService.insertByBo(bo));
}
/**
* 修改停机
*/
@Log(title = "停机", businessType = BusinessType.UPDATE)
@RepeatSubmit()
@PutMapping()
public R<Void> edit(@Validated(EditGroup.class) @RequestBody Klptcm1ProStoppageBo bo) {
return toAjax(iKlptcm1ProStoppageService.updateByBo(bo));
}
/**
* 删除停机
*
* @param STOPIDs 主键串
*/
@Log(title = "停机", businessType = BusinessType.DELETE)
@DeleteMapping("/{STOPIDs}")
public R<Void> remove(@NotEmpty(message = "主键不能为空")
@PathVariable Long[] STOPIDs) {
return toAjax(iKlptcm1ProStoppageService.deleteWithValidByIds(Arrays.asList(STOPIDs), true));
}
}

View File

@@ -0,0 +1,128 @@
package com.klp.pocket.domain;
import com.baomidou.mybatisplus.annotation.*;
import lombok.Data;
import java.math.BigDecimal;
import java.util.Date;
/**
* 历史对象 klptcm1_pro_plant_state_history
*
* @author klp
* @date 2025-10-27
*/
@Data
@TableName("klptcm1_pro_plant_state_history")
public class Klptcm1ProPlantStateHistory{
private static final long serialVersionUID=1L;
private Date insdate;
private Long year;
private Long month;
private Long day;
private Long hour;
private Long minute;
private Long type;
private BigDecimal value1;
private BigDecimal value2;
private BigDecimal value3;
private BigDecimal value4;
private BigDecimal value5;
private BigDecimal value6;
private BigDecimal value7;
private BigDecimal value8;
private BigDecimal value9;
private BigDecimal value10;
private BigDecimal value11;
private BigDecimal value12;
private BigDecimal value13;
private BigDecimal value14;
private BigDecimal value15;
private BigDecimal value16;
private BigDecimal value17;
private BigDecimal value18;
private BigDecimal value19;
private BigDecimal value20;
private BigDecimal value21;
private BigDecimal value22;
private BigDecimal value23;
private BigDecimal value24;
private BigDecimal value25;
private BigDecimal value26;
private BigDecimal value27;
private BigDecimal value28;
private BigDecimal value29;
private BigDecimal value30;
private BigDecimal value31;
private BigDecimal value32;
private BigDecimal value33;
private BigDecimal value34;
private BigDecimal value35;
private BigDecimal value36;
private BigDecimal value37;
private BigDecimal value38;
private BigDecimal value39;
private BigDecimal value40;
private BigDecimal value41;
private BigDecimal value42;
private BigDecimal value43;
private BigDecimal value44;
private BigDecimal value45;
private BigDecimal value46;
private BigDecimal value47;
private BigDecimal value48;
private BigDecimal value49;
private BigDecimal value50;
private BigDecimal value51;
private BigDecimal value52;
private BigDecimal value53;
private BigDecimal value54;
private BigDecimal value55;
private BigDecimal value56;
private BigDecimal value57;
private BigDecimal value58;
private BigDecimal value59;
private BigDecimal value60;
private BigDecimal value61;
private BigDecimal value62;
private BigDecimal value63;
private BigDecimal value64;
private BigDecimal value65;
private BigDecimal value66;
private BigDecimal value67;
private BigDecimal value68;
private BigDecimal value69;
private BigDecimal value70;
private BigDecimal value71;
private BigDecimal value72;
private BigDecimal value73;
private BigDecimal value74;
private BigDecimal value75;
private BigDecimal value76;
private BigDecimal value77;
private BigDecimal value78;
private BigDecimal value79;
private BigDecimal value80;
private BigDecimal value81;
private BigDecimal value82;
private BigDecimal value83;
private BigDecimal value84;
private BigDecimal value85;
private BigDecimal value86;
private BigDecimal value87;
private BigDecimal value88;
private BigDecimal value89;
private BigDecimal value90;
private BigDecimal value91;
private BigDecimal value92;
private BigDecimal value93;
private BigDecimal value94;
private BigDecimal value95;
private BigDecimal value96;
private BigDecimal value97;
private BigDecimal value98;
private BigDecimal value99;
}

View File

@@ -0,0 +1,34 @@
package com.klp.pocket.domain;
import com.baomidou.mybatisplus.annotation.*;
import lombok.Data;
import java.util.Date;
/**
* 停机对象 klptcm1_pro_stoppage
*
* @author klp
* @date 2025-10-27
*/
@Data
@TableName("klptcm1_pro_stoppage")
public class Klptcm1ProStoppage{
private static final long serialVersionUID=1L;
private Long stopid;
private String encoilid;
private String shift;
private String crew;
private String area;
private String unit;
private String seton;
private String remark;
private Date startDate;
private Date endDate;
private Long duration;
private Date insDate;
private String stopType;
}

View File

@@ -0,0 +1,554 @@
package com.klp.pocket.domain.bo;
import com.klp.common.core.domain.BaseEntity;
import lombok.Data;
import lombok.EqualsAndHashCode;
import javax.validation.constraints.*;
import java.math.BigDecimal;
import java.util.Date;
import com.fasterxml.jackson.annotation.JsonFormat;
/**
* 当前业务对象 klptcm1_pro_plant_state_current
*
* @author klp
* @date 2025-10-27
*/
@Data
@EqualsAndHashCode(callSuper = true)
public class Klptcm1ProPlantStateCurrentBo extends BaseEntity {
/**
*
*/
private Date INSDATE;
/**
*
*/
private Long YEAR;
/**
*
*/
private Long MONTH;
/**
*
*/
private Long DAY;
/**
*
*/
private Long HOUR;
/**
*
*/
private Long MINUTE;
/**
*
*/
private Long TYPE;
/**
*
*/
private BigDecimal VALUE1;
/**
*
*/
private BigDecimal VALUE2;
/**
*
*/
private BigDecimal VALUE3;
/**
*
*/
private BigDecimal VALUE4;
/**
*
*/
private BigDecimal VALUE5;
/**
*
*/
private BigDecimal VALUE6;
/**
*
*/
private BigDecimal VALUE7;
/**
*
*/
private BigDecimal VALUE8;
/**
*
*/
private BigDecimal VALUE9;
/**
*
*/
private BigDecimal VALUE10;
/**
*
*/
private BigDecimal VALUE11;
/**
*
*/
private BigDecimal VALUE12;
/**
*
*/
private BigDecimal VALUE13;
/**
*
*/
private BigDecimal VALUE14;
/**
*
*/
private BigDecimal VALUE15;
/**
*
*/
private BigDecimal VALUE16;
/**
*
*/
private BigDecimal VALUE17;
/**
*
*/
private BigDecimal VALUE18;
/**
*
*/
private BigDecimal VALUE19;
/**
*
*/
private BigDecimal VALUE20;
/**
*
*/
private BigDecimal VALUE21;
/**
*
*/
private BigDecimal VALUE22;
/**
*
*/
private BigDecimal VALUE23;
/**
*
*/
private BigDecimal VALUE24;
/**
*
*/
private BigDecimal VALUE25;
/**
*
*/
private BigDecimal VALUE26;
/**
*
*/
private BigDecimal VALUE27;
/**
*
*/
private BigDecimal VALUE28;
/**
*
*/
private BigDecimal VALUE29;
/**
*
*/
private BigDecimal VALUE30;
/**
*
*/
private BigDecimal VALUE31;
/**
*
*/
private BigDecimal VALUE32;
/**
*
*/
private BigDecimal VALUE33;
/**
*
*/
private BigDecimal VALUE34;
/**
*
*/
private BigDecimal VALUE35;
/**
*
*/
private BigDecimal VALUE36;
/**
*
*/
private BigDecimal VALUE37;
/**
*
*/
private BigDecimal VALUE38;
/**
*
*/
private BigDecimal VALUE39;
/**
*
*/
private BigDecimal VALUE40;
/**
*
*/
private BigDecimal VALUE41;
/**
*
*/
private BigDecimal VALUE42;
/**
*
*/
private BigDecimal VALUE43;
/**
*
*/
private BigDecimal VALUE44;
/**
*
*/
private BigDecimal VALUE45;
/**
*
*/
private BigDecimal VALUE46;
/**
*
*/
private BigDecimal VALUE47;
/**
*
*/
private BigDecimal VALUE48;
/**
*
*/
private BigDecimal VALUE49;
/**
*
*/
private BigDecimal VALUE50;
/**
*
*/
private BigDecimal VALUE51;
/**
*
*/
private BigDecimal VALUE52;
/**
*
*/
private BigDecimal VALUE53;
/**
*
*/
private BigDecimal VALUE54;
/**
*
*/
private BigDecimal VALUE55;
/**
*
*/
private BigDecimal VALUE56;
/**
*
*/
private BigDecimal VALUE57;
/**
*
*/
private BigDecimal VALUE58;
/**
*
*/
private BigDecimal VALUE59;
/**
*
*/
private BigDecimal VALUE60;
/**
*
*/
private BigDecimal VALUE61;
/**
*
*/
private BigDecimal VALUE62;
/**
*
*/
private BigDecimal VALUE63;
/**
*
*/
private BigDecimal VALUE64;
/**
*
*/
private BigDecimal VALUE65;
/**
*
*/
private BigDecimal VALUE66;
/**
*
*/
private BigDecimal VALUE67;
/**
*
*/
private BigDecimal VALUE68;
/**
*
*/
private BigDecimal VALUE69;
/**
*
*/
private BigDecimal VALUE70;
/**
*
*/
private BigDecimal VALUE71;
/**
*
*/
private BigDecimal VALUE72;
/**
*
*/
private BigDecimal VALUE73;
/**
*
*/
private BigDecimal VALUE74;
/**
*
*/
private BigDecimal VALUE75;
/**
*
*/
private BigDecimal VALUE76;
/**
*
*/
private BigDecimal VALUE77;
/**
*
*/
private BigDecimal VALUE78;
/**
*
*/
private BigDecimal VALUE79;
/**
*
*/
private BigDecimal VALUE80;
/**
*
*/
private BigDecimal VALUE81;
/**
*
*/
private BigDecimal VALUE82;
/**
*
*/
private BigDecimal VALUE83;
/**
*
*/
private BigDecimal VALUE84;
/**
*
*/
private BigDecimal VALUE85;
/**
*
*/
private BigDecimal VALUE86;
/**
*
*/
private BigDecimal VALUE87;
/**
*
*/
private BigDecimal VALUE88;
/**
*
*/
private BigDecimal VALUE89;
/**
*
*/
private BigDecimal VALUE90;
/**
*
*/
private BigDecimal VALUE91;
/**
*
*/
private BigDecimal VALUE92;
/**
*
*/
private BigDecimal VALUE93;
/**
*
*/
private BigDecimal VALUE94;
/**
*
*/
private BigDecimal VALUE95;
/**
*
*/
private BigDecimal VALUE96;
/**
*
*/
private BigDecimal VALUE97;
/**
*
*/
private BigDecimal VALUE98;
/**
*
*/
private BigDecimal VALUE99;
}

View File

@@ -0,0 +1,217 @@
package com.klp.pocket.domain.bo;
import com.klp.common.core.domain.BaseEntity;
import lombok.Data;
import lombok.EqualsAndHashCode;
import java.math.BigDecimal;
import java.util.Date;
/**
* 历史业务对象 klptcm1_pro_plant_state_history
*
* @author klp
* @date 2025-10-27
*/
@Data
@EqualsAndHashCode(callSuper = true)
public class Klptcm1ProPlantStateHistoryBo extends BaseEntity {
private Date INSDATE;
private Long YEAR;
private Long MONTH;
private Long DAY;
private Long HOUR;
private Long MINUTE;
private Long TYPE;
private BigDecimal VALUE1;
private BigDecimal VALUE2;
private BigDecimal VALUE3;
private BigDecimal VALUE4;
private BigDecimal VALUE5;
private BigDecimal VALUE6;
private BigDecimal VALUE7;
private BigDecimal VALUE8;
private BigDecimal VALUE9;
private BigDecimal VALUE10;
private BigDecimal VALUE11;
private BigDecimal VALUE12;
private BigDecimal VALUE13;
private BigDecimal VALUE14;
private BigDecimal VALUE15;
private BigDecimal VALUE16;
private BigDecimal VALUE17;
private BigDecimal VALUE18;
private BigDecimal VALUE19;
private BigDecimal VALUE20;
private BigDecimal VALUE21;
private BigDecimal VALUE22;
private BigDecimal VALUE23;
private BigDecimal VALUE24;
private BigDecimal VALUE25;
private BigDecimal VALUE26;
private BigDecimal VALUE27;
private BigDecimal VALUE28;
private BigDecimal VALUE29;
private BigDecimal VALUE30;
private BigDecimal VALUE31;
private BigDecimal VALUE32;
private BigDecimal VALUE33;
private BigDecimal VALUE34;
private BigDecimal VALUE35;
private BigDecimal VALUE36;
private BigDecimal VALUE37;
private BigDecimal VALUE38;
private BigDecimal VALUE39;
private BigDecimal VALUE40;
private BigDecimal VALUE41;
private BigDecimal VALUE42;
private BigDecimal VALUE43;
private BigDecimal VALUE44;
private BigDecimal VALUE45;
private BigDecimal VALUE46;
private BigDecimal VALUE47;
private BigDecimal VALUE48;
private BigDecimal VALUE49;
private BigDecimal VALUE50;
private BigDecimal VALUE51;
private BigDecimal VALUE52;
private BigDecimal VALUE53;
private BigDecimal VALUE54;
private BigDecimal VALUE55;
private BigDecimal VALUE56;
private BigDecimal VALUE57;
private BigDecimal VALUE58;
private BigDecimal VALUE59;
private BigDecimal VALUE60;
private BigDecimal VALUE61;
private BigDecimal VALUE62;
private BigDecimal VALUE63;
private BigDecimal VALUE64;
private BigDecimal VALUE65;
private BigDecimal VALUE66;
private BigDecimal VALUE67;
private BigDecimal VALUE68;
private BigDecimal VALUE69;
private BigDecimal VALUE70;
private BigDecimal VALUE71;
private BigDecimal VALUE72;
private BigDecimal VALUE73;
private BigDecimal VALUE74;
private BigDecimal VALUE75;
private BigDecimal VALUE76;
private BigDecimal VALUE77;
private BigDecimal VALUE78;
private BigDecimal VALUE79;
private BigDecimal VALUE80;
private BigDecimal VALUE81;
private BigDecimal VALUE82;
private BigDecimal VALUE83;
private BigDecimal VALUE84;
private BigDecimal VALUE85;
private BigDecimal VALUE86;
private BigDecimal VALUE87;
private BigDecimal VALUE88;
private BigDecimal VALUE89;
private BigDecimal VALUE90;
private BigDecimal VALUE91;
private BigDecimal VALUE92;
private BigDecimal VALUE93;
private BigDecimal VALUE94;
private BigDecimal VALUE95;
private BigDecimal VALUE96;
private BigDecimal VALUE97;
private BigDecimal VALUE98;
private BigDecimal VALUE99;
}

View File

@@ -0,0 +1,30 @@
package com.klp.pocket.domain.vo;
import lombok.Data;
import java.math.BigDecimal;
/**
* 班组产量统计视图对象
*/
@Data
public class CrewProductionVo {
/** 班组 */
private String crew;
/** 班次 */
private String shift;
/** 钢卷数 */
private Long coilCount;
/** 总产量 */
private BigDecimal totalWeight;
/** 平均厚度 */
private BigDecimal avgThick;
/** 平均宽度 */
private BigDecimal avgWidth;
}

View File

@@ -0,0 +1,33 @@
package com.klp.pocket.domain.vo;
import java.util.Date;
import com.alibaba.excel.annotation.ExcelIgnoreUnannotated;
import lombok.Data;
/**
* 停机视图对象 klptcm1_pro_stoppage
*
* @author klp
* @date 2025-10-27
*/
@Data
@ExcelIgnoreUnannotated
public class Klptcm1ProStoppageVo {
private static final long serialVersionUID = 1L;
private Long stopid;
private String encoilid;
private String shift;
private String crew;
private String area;
private String unit;
private String seton;
private String remark;
private Date startDate;
private Date endDate;
private Long duration;
private Date insDate;
private String stopType;
}

View File

@@ -0,0 +1,27 @@
package com.klp.pocket.domain.vo;
import lombok.Data;
import java.math.BigDecimal;
import java.util.Date;
@Data
public class PlantStateWithValueVo {
// define表基础字段
private BigDecimal id;
private String name;
private String units;
private String comments;
private Date insdate;
private BigDecimal modeltype;
// current表关联字段VALUE{ID} + 时间)
private BigDecimal currentValue;
private Date currentInsdate;
// history表关联字段VALUE{ID} + 时间)
private BigDecimal historyValue;
private Date historyInsdate;
}

View File

@@ -0,0 +1,30 @@
package com.klp.pocket.domain.vo;
import lombok.Data;
import java.math.BigDecimal;
/**
* 生产统计视图对象
*/
@Data
public class ProductionStatisticsVo {
/** 生产钢卷数 */
private Long coilCount;
/** 平均宽度 */
private BigDecimal avgWidth;
/** 平均厚度 */
private BigDecimal avgThick;
/** 原料总量 */
private BigDecimal totalEntryWeight;
/** 成品总量 */
private BigDecimal totalExitWeight;
/** 成材率 */
private BigDecimal yieldRate;
}

View File

@@ -0,0 +1,42 @@
package com.klp.pocket.domain.vo;
import lombok.Data;
import java.math.BigDecimal;
/**
* 班组绩效视图对象
*/
@Data
public class TeamPerformanceVo {
/** 班组 */
private String crew;
/** 班次 */
private String shift;
/** 班组-班次组合(用于显示) */
private String teamName;
/** 产量(t) */
private BigDecimal output;
/** 成材率(%) */
private BigDecimal yieldRate;
/** 合格率(%) - 基于厚度质量 */
private BigDecimal passRate;
/** 平均厚度质量 */
private BigDecimal avgThickQuality;
/** 平均板形质量 */
private BigDecimal avgShapeQuality;
/** 效率指标(钢卷数/时间,这里简化为钢卷数) */
private Long efficiency;
/** 综合评分 */
private BigDecimal score;
}

View File

@@ -0,0 +1,63 @@
package com.klp.pocket.mapper;
import com.klp.pocket.domain.vo.ProductionStatisticsVo;
import com.klp.pocket.domain.vo.CrewProductionVo;
import com.klp.pocket.domain.vo.SpecDistributionVo;
import com.klp.pocket.domain.vo.TeamPerformanceVo;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Param;
import java.util.List;
/**
* 成品卷Mapper接口
*/
@Mapper
public interface Klptcm1PdoExcoilMapper {
/**
* 查询生产统计汇总数据
* @param startDate 开始日期
* @param endDate 结束日期
* @return 统计数据
*/
ProductionStatisticsVo selectProductionStatistics(@Param("startDate") String startDate,
@Param("endDate") String endDate);
/**
* 查询班组产量统计
* @param startDate 开始日期
* @param endDate 结束日期
* @return 班组产量列表
*/
List<CrewProductionVo> selectCrewProduction(@Param("startDate") String startDate,
@Param("endDate") String endDate);
/**
* 查询厚度分布
* @param startDate 开始日期
* @param endDate 结束日期
* @return 厚度分布列表
*/
List<SpecDistributionVo> selectThicknessDistribution(@Param("startDate") String startDate,
@Param("endDate") String endDate);
/**
* 查询宽度分布
* @param startDate 开始日期
* @param endDate 结束日期
* @return 宽度分布列表
*/
List<SpecDistributionVo> selectWidthDistribution(@Param("startDate") String startDate,
@Param("endDate") String endDate);
/**
* 查询班组绩效统计
* @param startDate 开始日期
* @param endDate 结束日期
* @return 班组绩效列表
*/
List<TeamPerformanceVo> selectTeamPerformance(@Param("startDate") String startDate,
@Param("endDate") String endDate);
}

View File

@@ -0,0 +1,30 @@
package com.klp.pocket.mapper;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.klp.common.core.domain.PageQuery;
import com.klp.common.core.page.TableDataInfo;
import com.klp.pocket.domain.Klptcm1ProPlantStateCurrent;
import org.apache.ibatis.annotations.Mapper;
import java.util.List;
import java.util.Date;
import java.math.BigDecimal;
import org.apache.ibatis.annotations.Param;
@Mapper
public interface Klptcm1ProPlantStateCurrentMapper {
// 查询所有
Page<Klptcm1ProPlantStateCurrent> selectAll(Page<Object> build);
// 按复合键查询
Klptcm1ProPlantStateCurrent selectOne(@Param("insdate") Date insdate, @Param("type") BigDecimal type);
// 新增
int insert(Klptcm1ProPlantStateCurrent entity);
// 修改(按复合键)
int updateByKey(Klptcm1ProPlantStateCurrent entity);
// 删除(按复合键)
int deleteByKey(@Param("insdate") Date insdate, @Param("type") BigDecimal type);
}

View File

@@ -0,0 +1,53 @@
package com.klp.pocket.mapper;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.klp.pocket.domain.Klptcm1ProPlantStateDefine;
import com.klp.pocket.domain.vo.PlantStateWithValueVo;
import org.apache.ibatis.annotations.Mapper;
import com.baomidou.mybatisplus.core.metadata.IPage;
import java.math.BigDecimal;
import java.util.List;
/**
* 工厂状态定义表Mapper接口
* 提供增删改查及分页查询能力
*/
@Mapper
public interface Klptcm1ProPlantStateDefineMapper {
/**
* 分页查询所有状态定义
* @param page 分页参数(含页码、每页条数)
* @return 分页结果(含总条数、当前页数据)
*/
Page<Klptcm1ProPlantStateDefine> selectPage(Page<Object> page);
List<PlantStateWithValueVo> selectByValue(String name);
/**
* 获取所有定义及其当前值
* @return 所有定义列表,每个定义包含对应的当前值
*/
List<PlantStateWithValueVo> selectAllWithValues();
/**
* 按ID查询
*/
Klptcm1ProPlantStateDefine selectById(BigDecimal id);
/**
* 新增
*/
int insert(Klptcm1ProPlantStateDefine entity);
/**
* 修改
*/
int updateById(Klptcm1ProPlantStateDefine entity);
/**
* 删除(批量)
*/
int deleteByIds(List<BigDecimal> ids);
}

View File

@@ -0,0 +1,19 @@
package com.klp.pocket.mapper;
import com.klp.pocket.domain.Klptcm1ShiftCurrent;
import com.klp.pocket.domain.vo.Klptcm1ShiftCurrentVo;
import org.apache.ibatis.annotations.Mapper;
/**
* 当前班组Mapper接口
*/
@Mapper
public interface Klptcm1ShiftCurrentMapper {
/**
* 查询当前班组信息(最新一条)
* @return 当前班组信息
*/
Klptcm1ShiftCurrentVo selectCurrent();
}

View File

@@ -0,0 +1,41 @@
package com.klp.pocket.service;
import com.klp.common.core.domain.PageQuery;
import com.klp.common.core.page.TableDataInfo;
import com.klp.pocket.domain.Klptcm1ProPlantStateDefine;
import com.klp.pocket.domain.vo.PlantStateWithValueVo;
import java.math.BigDecimal;
import java.util.List;
/**
* 工厂状态定义表Service接口
* 封装业务逻辑,对外提供数据操作能力
*/
public interface IKlptcm1ProPlantStateDefineService {
/**
* 分页查询状态定义
* @param pageQuery 分页查询参数(含页码、每页条数)
* @return 分页表格数据符合前端TableDataInfo格式
*/
TableDataInfo<Klptcm1ProPlantStateDefine> getDefinePage(PageQuery pageQuery);
List<PlantStateWithValueVo> selectByValue(String name);
/**
* 获取所有定义及其当前值
* @return 所有定义列表,每个定义包含对应的当前值
*/
List<PlantStateWithValueVo> selectAllWithValues();
Klptcm1ProPlantStateDefine selectById(BigDecimal id);
int insert(Klptcm1ProPlantStateDefine entity);
int updateById(Klptcm1ProPlantStateDefine entity);
int deleteByIds(List<BigDecimal> ids);
}

View File

@@ -0,0 +1,218 @@
package com.klp.pocket.service.impl;
import cn.hutool.core.bean.BeanUtil;
import com.baomidou.dynamic.datasource.annotation.DS;
import com.klp.common.core.page.TableDataInfo;
import com.klp.common.core.domain.PageQuery;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
import com.baomidou.mybatisplus.core.toolkit.Wrappers;
import lombok.RequiredArgsConstructor;
import org.springframework.stereotype.Service;
import com.klp.pocket.domain.bo.Klptcm1ProPlantStateHistoryBo;
import com.klp.pocket.domain.vo.Klptcm1ProPlantStateHistoryVo;
import com.klp.pocket.domain.Klptcm1ProPlantStateHistory;
import com.klp.pocket.mapper.Klptcm1ProPlantStateHistoryMapper;
import com.klp.pocket.service.IKlptcm1ProPlantStateHistoryService;
import java.util.Collection;
import java.util.Date;
import java.util.List;
import java.util.Map;
/**
* 历史Service业务层处理
*
* @author klp
* @date 2025-10-27
*/
@RequiredArgsConstructor
@DS("slave")
@Service
public class Klptcm1ProPlantStateHistoryServiceImpl implements IKlptcm1ProPlantStateHistoryService {
private final Klptcm1ProPlantStateHistoryMapper baseMapper;
/**
* 查询历史
*/
@Override
public Klptcm1ProPlantStateHistoryVo queryById(Date INSDATE){
return baseMapper.selectVoById(INSDATE);
}
/**
* 查询历史列表
*/
@Override
public TableDataInfo<Klptcm1ProPlantStateHistoryVo> queryPageList(Klptcm1ProPlantStateHistoryBo bo, PageQuery pageQuery) {
LambdaQueryWrapper<Klptcm1ProPlantStateHistory> lqw = buildQueryWrapper(bo);
Page<Klptcm1ProPlantStateHistoryVo> result = baseMapper.selectVoPage(pageQuery.build(), lqw);
return TableDataInfo.build(result);
}
/**
* 查询历史列表
*/
@Override
public List<Klptcm1ProPlantStateHistoryVo> queryList(Klptcm1ProPlantStateHistoryBo bo) {
LambdaQueryWrapper<Klptcm1ProPlantStateHistory> lqw = buildQueryWrapper(bo);
return baseMapper.selectVoList(lqw);
}
private LambdaQueryWrapper<Klptcm1ProPlantStateHistory> buildQueryWrapper(Klptcm1ProPlantStateHistoryBo bo) {
Map<String, Object> params = bo.getParams();
LambdaQueryWrapper<Klptcm1ProPlantStateHistory> lqw = Wrappers.lambdaQuery();
lqw.eq(bo.getINSDATE() != null, Klptcm1ProPlantStateHistory::getInsdate, bo.getINSDATE());
lqw.eq(bo.getYEAR() != null, Klptcm1ProPlantStateHistory::getYear, bo.getYEAR());
lqw.eq(bo.getMONTH() != null, Klptcm1ProPlantStateHistory::getMonth, bo.getMONTH());
lqw.eq(bo.getDAY() != null, Klptcm1ProPlantStateHistory::getDay, bo.getDAY());
lqw.eq(bo.getHOUR() != null, Klptcm1ProPlantStateHistory::getHour, bo.getHOUR());
lqw.eq(bo.getMINUTE() != null, Klptcm1ProPlantStateHistory::getMinute, bo.getMINUTE());
lqw.eq(bo.getTYPE() != null, Klptcm1ProPlantStateHistory::getType, bo.getTYPE());
lqw.eq(bo.getVALUE1() != null, Klptcm1ProPlantStateHistory::getValue1, bo.getVALUE1());
lqw.eq(bo.getVALUE2() != null, Klptcm1ProPlantStateHistory::getValue2, bo.getVALUE2());
lqw.eq(bo.getVALUE3() != null, Klptcm1ProPlantStateHistory::getValue3, bo.getVALUE3());
lqw.eq(bo.getVALUE4() != null, Klptcm1ProPlantStateHistory::getValue4, bo.getVALUE4());
lqw.eq(bo.getVALUE5() != null, Klptcm1ProPlantStateHistory::getValue5, bo.getVALUE5());
lqw.eq(bo.getVALUE6() != null, Klptcm1ProPlantStateHistory::getValue6, bo.getVALUE6());
lqw.eq(bo.getVALUE7() != null, Klptcm1ProPlantStateHistory::getValue7, bo.getVALUE7());
lqw.eq(bo.getVALUE8() != null, Klptcm1ProPlantStateHistory::getValue8, bo.getVALUE8());
lqw.eq(bo.getVALUE9() != null, Klptcm1ProPlantStateHistory::getValue9, bo.getVALUE9());
lqw.eq(bo.getVALUE10() != null, Klptcm1ProPlantStateHistory::getValue10, bo.getVALUE10());
lqw.eq(bo.getVALUE11() != null, Klptcm1ProPlantStateHistory::getValue11, bo.getVALUE11());
lqw.eq(bo.getVALUE12() != null, Klptcm1ProPlantStateHistory::getValue12, bo.getVALUE12());
lqw.eq(bo.getVALUE13() != null, Klptcm1ProPlantStateHistory::getValue13, bo.getVALUE13());
lqw.eq(bo.getVALUE14() != null, Klptcm1ProPlantStateHistory::getValue14, bo.getVALUE14());
lqw.eq(bo.getVALUE15() != null, Klptcm1ProPlantStateHistory::getValue15, bo.getVALUE15());
lqw.eq(bo.getVALUE16() != null, Klptcm1ProPlantStateHistory::getValue16, bo.getVALUE16());
lqw.eq(bo.getVALUE17() != null, Klptcm1ProPlantStateHistory::getValue17, bo.getVALUE17());
lqw.eq(bo.getVALUE18() != null, Klptcm1ProPlantStateHistory::getValue18, bo.getVALUE18());
lqw.eq(bo.getVALUE19() != null, Klptcm1ProPlantStateHistory::getValue19, bo.getVALUE19());
lqw.eq(bo.getVALUE20() != null, Klptcm1ProPlantStateHistory::getValue20, bo.getVALUE20());
lqw.eq(bo.getVALUE21() != null, Klptcm1ProPlantStateHistory::getValue21, bo.getVALUE21());
lqw.eq(bo.getVALUE22() != null, Klptcm1ProPlantStateHistory::getValue22, bo.getVALUE22());
lqw.eq(bo.getVALUE23() != null, Klptcm1ProPlantStateHistory::getValue23, bo.getVALUE23());
lqw.eq(bo.getVALUE24() != null, Klptcm1ProPlantStateHistory::getValue24, bo.getVALUE24());
lqw.eq(bo.getVALUE25() != null, Klptcm1ProPlantStateHistory::getValue25, bo.getVALUE25());
lqw.eq(bo.getVALUE26() != null, Klptcm1ProPlantStateHistory::getValue26, bo.getVALUE26());
lqw.eq(bo.getVALUE27() != null, Klptcm1ProPlantStateHistory::getValue27, bo.getVALUE27());
lqw.eq(bo.getVALUE28() != null, Klptcm1ProPlantStateHistory::getValue28, bo.getVALUE28());
lqw.eq(bo.getVALUE29() != null, Klptcm1ProPlantStateHistory::getValue29, bo.getVALUE29());
lqw.eq(bo.getVALUE30() != null, Klptcm1ProPlantStateHistory::getValue30, bo.getVALUE30());
lqw.eq(bo.getVALUE31() != null, Klptcm1ProPlantStateHistory::getValue31, bo.getVALUE31());
lqw.eq(bo.getVALUE32() != null, Klptcm1ProPlantStateHistory::getValue32, bo.getVALUE32());
lqw.eq(bo.getVALUE33() != null, Klptcm1ProPlantStateHistory::getValue33, bo.getVALUE33());
lqw.eq(bo.getVALUE34() != null, Klptcm1ProPlantStateHistory::getValue34, bo.getVALUE34());
lqw.eq(bo.getVALUE35() != null, Klptcm1ProPlantStateHistory::getValue35, bo.getVALUE35());
lqw.eq(bo.getVALUE36() != null, Klptcm1ProPlantStateHistory::getValue36, bo.getVALUE36());
lqw.eq(bo.getVALUE37() != null, Klptcm1ProPlantStateHistory::getValue37, bo.getVALUE37());
lqw.eq(bo.getVALUE38() != null, Klptcm1ProPlantStateHistory::getValue38, bo.getVALUE38());
lqw.eq(bo.getVALUE39() != null, Klptcm1ProPlantStateHistory::getValue39, bo.getVALUE39());
lqw.eq(bo.getVALUE40() != null, Klptcm1ProPlantStateHistory::getValue40, bo.getVALUE40());
lqw.eq(bo.getVALUE41() != null, Klptcm1ProPlantStateHistory::getValue41, bo.getVALUE41());
lqw.eq(bo.getVALUE42() != null, Klptcm1ProPlantStateHistory::getValue42, bo.getVALUE42());
lqw.eq(bo.getVALUE43() != null, Klptcm1ProPlantStateHistory::getValue43, bo.getVALUE43());
lqw.eq(bo.getVALUE44() != null, Klptcm1ProPlantStateHistory::getValue44, bo.getVALUE44());
lqw.eq(bo.getVALUE45() != null, Klptcm1ProPlantStateHistory::getValue45, bo.getVALUE45());
lqw.eq(bo.getVALUE46() != null, Klptcm1ProPlantStateHistory::getValue46, bo.getVALUE46());
lqw.eq(bo.getVALUE47() != null, Klptcm1ProPlantStateHistory::getValue47, bo.getVALUE47());
lqw.eq(bo.getVALUE48() != null, Klptcm1ProPlantStateHistory::getValue48, bo.getVALUE48());
lqw.eq(bo.getVALUE49() != null, Klptcm1ProPlantStateHistory::getValue49, bo.getVALUE49());
lqw.eq(bo.getVALUE50() != null, Klptcm1ProPlantStateHistory::getValue50, bo.getVALUE50());
lqw.eq(bo.getVALUE51() != null, Klptcm1ProPlantStateHistory::getValue51, bo.getVALUE51());
lqw.eq(bo.getVALUE52() != null, Klptcm1ProPlantStateHistory::getValue52, bo.getVALUE52());
lqw.eq(bo.getVALUE53() != null, Klptcm1ProPlantStateHistory::getValue53, bo.getVALUE53());
lqw.eq(bo.getVALUE54() != null, Klptcm1ProPlantStateHistory::getValue54, bo.getVALUE54());
lqw.eq(bo.getVALUE55() != null, Klptcm1ProPlantStateHistory::getValue55, bo.getVALUE55());
lqw.eq(bo.getVALUE56() != null, Klptcm1ProPlantStateHistory::getValue56, bo.getVALUE56());
lqw.eq(bo.getVALUE57() != null, Klptcm1ProPlantStateHistory::getValue57, bo.getVALUE57());
lqw.eq(bo.getVALUE58() != null, Klptcm1ProPlantStateHistory::getValue58, bo.getVALUE58());
lqw.eq(bo.getVALUE59() != null, Klptcm1ProPlantStateHistory::getValue59, bo.getVALUE59());
lqw.eq(bo.getVALUE60() != null, Klptcm1ProPlantStateHistory::getValue60, bo.getVALUE60());
lqw.eq(bo.getVALUE61() != null, Klptcm1ProPlantStateHistory::getValue61, bo.getVALUE61());
lqw.eq(bo.getVALUE62() != null, Klptcm1ProPlantStateHistory::getValue62, bo.getVALUE62());
lqw.eq(bo.getVALUE63() != null, Klptcm1ProPlantStateHistory::getValue63, bo.getVALUE63());
lqw.eq(bo.getVALUE64() != null, Klptcm1ProPlantStateHistory::getValue64, bo.getVALUE64());
lqw.eq(bo.getVALUE65() != null, Klptcm1ProPlantStateHistory::getValue65, bo.getVALUE65());
lqw.eq(bo.getVALUE66() != null, Klptcm1ProPlantStateHistory::getValue66, bo.getVALUE66());
lqw.eq(bo.getVALUE67() != null, Klptcm1ProPlantStateHistory::getValue67, bo.getVALUE67());
lqw.eq(bo.getVALUE68() != null, Klptcm1ProPlantStateHistory::getValue68, bo.getVALUE68());
lqw.eq(bo.getVALUE69() != null, Klptcm1ProPlantStateHistory::getValue69, bo.getVALUE69());
lqw.eq(bo.getVALUE70() != null, Klptcm1ProPlantStateHistory::getValue70, bo.getVALUE70());
lqw.eq(bo.getVALUE71() != null, Klptcm1ProPlantStateHistory::getValue71, bo.getVALUE71());
lqw.eq(bo.getVALUE72() != null, Klptcm1ProPlantStateHistory::getValue72, bo.getVALUE72());
lqw.eq(bo.getVALUE73() != null, Klptcm1ProPlantStateHistory::getValue73, bo.getVALUE73());
lqw.eq(bo.getVALUE74() != null, Klptcm1ProPlantStateHistory::getValue74, bo.getVALUE74());
lqw.eq(bo.getVALUE75() != null, Klptcm1ProPlantStateHistory::getValue75, bo.getVALUE75());
lqw.eq(bo.getVALUE76() != null, Klptcm1ProPlantStateHistory::getValue76, bo.getVALUE76());
lqw.eq(bo.getVALUE77() != null, Klptcm1ProPlantStateHistory::getValue77, bo.getVALUE77());
lqw.eq(bo.getVALUE78() != null, Klptcm1ProPlantStateHistory::getValue78, bo.getVALUE78());
lqw.eq(bo.getVALUE79() != null, Klptcm1ProPlantStateHistory::getValue79, bo.getVALUE79());
lqw.eq(bo.getVALUE80() != null, Klptcm1ProPlantStateHistory::getValue80, bo.getVALUE80());
lqw.eq(bo.getVALUE81() != null, Klptcm1ProPlantStateHistory::getValue81, bo.getVALUE81());
lqw.eq(bo.getVALUE82() != null, Klptcm1ProPlantStateHistory::getValue82, bo.getVALUE82());
lqw.eq(bo.getVALUE83() != null, Klptcm1ProPlantStateHistory::getValue83, bo.getVALUE83());
lqw.eq(bo.getVALUE84() != null, Klptcm1ProPlantStateHistory::getValue84, bo.getVALUE84());
lqw.eq(bo.getVALUE85() != null, Klptcm1ProPlantStateHistory::getValue85, bo.getVALUE85());
lqw.eq(bo.getVALUE86() != null, Klptcm1ProPlantStateHistory::getValue86, bo.getVALUE86());
lqw.eq(bo.getVALUE87() != null, Klptcm1ProPlantStateHistory::getValue87, bo.getVALUE87());
lqw.eq(bo.getVALUE88() != null, Klptcm1ProPlantStateHistory::getValue88, bo.getVALUE88());
lqw.eq(bo.getVALUE89() != null, Klptcm1ProPlantStateHistory::getValue89, bo.getVALUE89());
lqw.eq(bo.getVALUE90() != null, Klptcm1ProPlantStateHistory::getValue90, bo.getVALUE90());
lqw.eq(bo.getVALUE91() != null, Klptcm1ProPlantStateHistory::getValue91, bo.getVALUE91());
lqw.eq(bo.getVALUE92() != null, Klptcm1ProPlantStateHistory::getValue92, bo.getVALUE92());
lqw.eq(bo.getVALUE93() != null, Klptcm1ProPlantStateHistory::getValue93, bo.getVALUE93());
lqw.eq(bo.getVALUE94() != null, Klptcm1ProPlantStateHistory::getValue94, bo.getVALUE94());
lqw.eq(bo.getVALUE95() != null, Klptcm1ProPlantStateHistory::getValue95, bo.getVALUE95());
lqw.eq(bo.getVALUE96() != null, Klptcm1ProPlantStateHistory::getValue96, bo.getVALUE96());
lqw.eq(bo.getVALUE97() != null, Klptcm1ProPlantStateHistory::getValue97, bo.getVALUE97());
lqw.eq(bo.getVALUE98() != null, Klptcm1ProPlantStateHistory::getValue98, bo.getVALUE98());
lqw.eq(bo.getVALUE99() != null, Klptcm1ProPlantStateHistory::getValue99, bo.getVALUE99());
//倒叙
lqw.orderByDesc(Klptcm1ProPlantStateHistory::getInsdate);
return lqw;
}
/**
* 新增历史
*/
@Override
public Boolean insertByBo(Klptcm1ProPlantStateHistoryBo bo) {
Klptcm1ProPlantStateHistory add = BeanUtil.toBean(bo, Klptcm1ProPlantStateHistory.class);
validEntityBeforeSave(add);
boolean flag = baseMapper.insert(add) > 0;
if (flag) {
bo.setINSDATE(add.getInsdate());
}
return flag;
}
/**
* 修改历史
*/
@Override
public Boolean updateByBo(Klptcm1ProPlantStateHistoryBo bo) {
Klptcm1ProPlantStateHistory update = BeanUtil.toBean(bo, Klptcm1ProPlantStateHistory.class);
validEntityBeforeSave(update);
return baseMapper.updateById(update) > 0;
}
/**
* 保存前的数据校验
*/
private void validEntityBeforeSave(Klptcm1ProPlantStateHistory entity){
//TODO 做一些数据校验,如唯一约束
}
/**
* 批量删除历史
*/
@Override
public Boolean deleteWithValidByIds(Collection<Date> ids, Boolean isValid) {
if(isValid){
//TODO 做一些业务上的校验,判断是否需要校验
}
return baseMapper.deleteBatchIds(ids) > 0;
}
}