日生产效率报表

master
zhaoxiaolin 1 week ago
parent 8ef77313cf
commit 867239f109

@ -212,8 +212,8 @@ public class MesLineAssistantQtyController extends BaseController {
// workbook.dispose();
// }
// }
ExcelUtil<MesDailyEfficiencyVo> util = new ExcelUtil<MesDailyEfficiencyVo>(MesDailyEfficiencyVo. class);
util.exportExcel(response, list, "生产日效率报表");
// ExcelUtil<MesDailyEfficiencyVo> util = new ExcelUtil<MesDailyEfficiencyVo>(MesDailyEfficiencyVo. class);
// util.exportExcel(response, list, "生产日效率报表");
}

@ -212,6 +212,15 @@ public class MesReportWork extends BaseEntity {
private String version;
private String sapCode;
private String remark;
private String checkResult;
public String getCheckResult() {
return checkResult;
}
public void setCheckResult(String checkResult) {
this.checkResult = checkResult;
}
public String getShiftName() {
return shiftName;

@ -60,15 +60,15 @@ private static final long serialVersionUID=1L;
@Excel(name = "产量达成率")
private String completeRate;
//一线
@Excel(name = "标准工艺效率PC/H")
@Excel(name = "一线标准工艺效率PC/H")
private String standEff;
@Excel(name = "标准用人")
@Excel(name = "一线标准用人")
private String standMan;
@Excel(name = "实际用人")
@Excel(name = "一线实际用人")
private String actMan;
@Excel(name = "产品标准工时")
@Excel(name = "一线产品标准工时")
private String standHour;
@Excel(name = "产品实际工时")
@Excel(name = "一线产品实际工时")
private String actHour;
@Excel(name = "一线工时合计")
private String oneHourSum;
@ -76,75 +76,75 @@ private static final long serialVersionUID=1L;
private String oneStandEff;
@Excel(name = "一线实际效率")
private String oneActEff;
@Excel(name = "效率达成率")
@Excel(name = "一线效率达成率")
private String effRate;
//辅助
////辅助用人数
@Excel(name = "辅助用人合计")
private String assisManSum;
@Excel(name = "班长人数")
@Excel(name = "辅助班长人数")
private String monitorQty;
@Excel(name = "组长人数")
@Excel(name = "辅助组长人数")
private String groupleaderQty;
@Excel(name = "机操工人数")
@Excel(name = "辅助机操工人数")
private String operateMachineQty;
@Excel(name = "物料员人数")
@Excel(name = "辅助物料员人数")
private String materialQty;
@Excel(name = "配料员人数")
@Excel(name = "辅助配料员人数")
private String materialDisQty;
@Excel(name = "配药员人数")
@Excel(name = "辅助配药员人数")
private String pillDisQty;
@Excel(name = "药管员人数")
@Excel(name = "辅助药管员人数")
private String pillMgrQty;
@Excel(name = "锅炉工人数")
@Excel(name = "辅助锅炉工人数")
private String boilerQty;
@Excel(name = "石油气看管员人数")
@Excel(name = "辅助石油气看管员人数")
private String oilQty;
@Excel(name = "库区管理员人数")
@Excel(name = "辅助库区管理员人数")
private String wareMgrQty;
@Excel(name = "机修工人数")
@Excel(name = "辅助机修工人数")
private String repairQty;
@Excel(name = "清洁工人数")
@Excel(name = "辅助清洁工人数")
private String cleanerQty;
////辅助工时数
@Excel(name = "辅助工时合计")
private String assisHourSum;
@Excel(name = "班长工时")
@Excel(name = "辅助班长工时")
private String monitorHour;
@Excel(name = "组长工时")
@Excel(name = "辅助组长工时")
private String groupleaderHour;
@Excel(name = "机操工工时")
@Excel(name = "辅助机操工工时")
private String operateMachineHour;
@Excel(name = "物料员工时")
@Excel(name = "辅助物料员工时")
private String materialHour;
@Excel(name = "配料员工时")
@Excel(name = "辅助配料员工时")
private String materialDisHour;
@Excel(name = "配药员工时")
@Excel(name = "辅助配药员工时")
private String pillDisHour;
@Excel(name = "药管员工时")
@Excel(name = "辅助药管员工时")
private String pillMgrHour;
@Excel(name = "锅炉工工时")
@Excel(name = "辅助锅炉工工时")
private String boilerHour;
@Excel(name = "石油气看管员工时")
@Excel(name = "辅助石油气看管员工时")
private String oilHour;
@Excel(name = "库区管理员工时")
@Excel(name = "辅助库区管理员工时")
private String wareMgrHour;
@Excel(name = "机修工工时")
@Excel(name = "辅助机修工工时")
private String repairHour;
@Excel(name = "清洁工工时")
@Excel(name = "辅助清洁工工时")
private String cleanerHour;
//一线+辅助
@Excel(name = "总工时")
@Excel(name = "一线+辅助总工时")
private String hourSum;
@Excel(name = "效率提升基数")
@Excel(name = "一线+辅助效率提升基数")
private String effUpBase;
@Excel(name = "提升目标")
@Excel(name = "一线+辅助提升目标")
private String upGoal;
@Excel(name = "目标效率")
@Excel(name = "一线+辅助目标效率")
private String goalRate;
@Excel(name = "实际效率")
@Excel(name = "一线+辅助实际效率")
private String actRate;
@Excel(name = "效率提升率")
@Excel(name = "一线+辅助效率提升率")
private String effUpRate;
@Excel(name = "原因分析")
private String reasonAnalysis;

@ -3,6 +3,7 @@ package com.op.mes.service.impl;
import java.math.BigDecimal;
import java.util.List;
import java.util.Map;
import java.util.stream.Collectors;
import com.alibaba.nacos.common.utils.CollectionUtils;
import com.baomidou.dynamic.datasource.annotation.DS;
@ -148,59 +149,67 @@ public class MesLineAssistantQtyServiceImpl implements IMesLineAssistantQtyServi
hours = hours==null?BigDecimal.ZERO:hours;
assistdto.setProductHour(hours.toString());
allProHours = allProHours.add(hours);
}
for(MesLineAssistantQtyVo assistdto:dtos){
//工时占比
assistdto.setHourRatio(new BigDecimal(assistdto.getProductHour())
.multiply(new BigDecimal("100.00"))
.divide(allProHours,2,BigDecimal.ROUND_HALF_UP)
.toString()+"%"
);
if(!assistMaps.isEmpty()){
MesLineAssistantQty manQty = assistMaps.get(mesLineAssistant.getProductDateStr());
if(manQty!=null){
//班长用人=当日人数/线体数
//班长用人=当日人数*工时占比
assistdto.setMonitorQty(new BigDecimal(manQty.getMonitorQty())
.divide(new BigDecimal(dtos.size()),2,BigDecimal.ROUND_HALF_UP)
.multiply(new BigDecimal(assistdto.getHourRatio().replace("%","")))
.toString()
);
//班长工时=当日考勤小时数/线体数
//班长工时=当日考勤小时数*工时占比
assistdto.setMonitorHour(
monitorHour.divide(new BigDecimal(dtos.size()),2,BigDecimal.ROUND_HALF_UP).toString());
//组长用人=当日人数/线体数
monitorHour.multiply(
new BigDecimal(assistdto.getHourRatio().replace("%",""))).toString());
//组长用人=当日人数*工时占比
assistdto.setGroupleaderQty(new BigDecimal(manQty.getGroupleaderQty())
.divide(new BigDecimal(dtos.size()),2,BigDecimal.ROUND_HALF_UP)
.multiply(new BigDecimal(assistdto.getHourRatio().replace("%","")))
.toString()
);
//组长工时=当日考勤小时数/线体数
//组长工时=当日考勤小时数*工时占比
assistdto.setGroupLeaderHour(
groupleadeHour.divide(new BigDecimal(dtos.size()),2,BigDecimal.ROUND_HALF_UP).toString());
//物料员用人=当日人数/线体数
groupleadeHour.multiply(
new BigDecimal(assistdto.getHourRatio().replace("%",""))).toString());
//物料员用人=当日人数*工时占比
assistdto.setMaterialQty(new BigDecimal(manQty.getMaterialQty())
.divide(new BigDecimal(dtos.size()),2,BigDecimal.ROUND_HALF_UP)
.multiply(new BigDecimal(assistdto.getHourRatio().replace("%","")))
.toString()
);
//物料员工时=当日考勤小时数/线体数
//物料员工时=当日考勤小时数*工时占比
assistdto.setMaterialHour(
materialHour.divide(new BigDecimal(dtos.size()),2,BigDecimal.ROUND_HALF_UP).toString());
//药管员用人=当日人数/线体数
materialHour.multiply(
new BigDecimal(assistdto.getHourRatio().replace("%",""))).toString());
//药管员用人=当日人数*工时占比
assistdto.setPillMgrQty(new BigDecimal(manQty.getPillMgrQty())
.divide(new BigDecimal(dtos.size()),2,BigDecimal.ROUND_HALF_UP)
.multiply(new BigDecimal(assistdto.getHourRatio().replace("%","")))
.toString()
);
//药管员工时=当日考勤小时数/线体数
//药管员工时=当日考勤小时数*工时占比
assistdto.setPillMgrHour(
pillMgrHour.divide(new BigDecimal(dtos.size()),2,BigDecimal.ROUND_HALF_UP).toString());
//配药员用人=当日人数/线体数
pillMgrHour.multiply(new BigDecimal(assistdto.getHourRatio().replace("%",""))).toString());
//配药员用人=当日人数*工时占比
assistdto.setPillDisQty(new BigDecimal(manQty.getPillDisQty())
.divide(new BigDecimal(dtos.size()),2,BigDecimal.ROUND_HALF_UP)
.multiply(new BigDecimal(assistdto.getHourRatio().replace("%","")))
.toString()
);
//配药员工时=当日考勤小时数/线体数
assistdto.setPillDisHour(
pillDisHour.divide(new BigDecimal(dtos.size()),2,BigDecimal.ROUND_HALF_UP).toString());
pillDisHour.multiply(
new BigDecimal(assistdto.getHourRatio().replace("%",""))).toString());
}
}
}
for(MesLineAssistantQtyVo assistdto:dtos){
//工时占比
assistdto.setHourRatio(new BigDecimal(assistdto.getProductHour())
.multiply(new BigDecimal("100.00"))
.divide(allProHours,2,BigDecimal.ROUND_HALF_UP)
.toString()+"%"
);
//辅助工时合计
assistdto.setMonitorHour(StringUtils.isEmpty(assistdto.getMonitorHour())?"0":assistdto.getMonitorHour());
assistdto.setGroupLeaderHour(StringUtils.isEmpty(assistdto.getGroupLeaderHour())?"0":assistdto.getGroupLeaderHour());
@ -240,6 +249,14 @@ public class MesLineAssistantQtyServiceImpl implements IMesLineAssistantQtyServi
assistdto0.setPillDisQty(manQty.getPillDisQty().toString());
assistdto0.setPillDisHour(pillDisHour.toString());
dtos.add(assistdto0);
if(StringUtils.isNotBlank(mesLineAssistant.getLineCode())){
dtos = dtos.stream().filter(dto ->(dto.getLineCode().equals(mesLineAssistant.getLineCode())))
.collect(Collectors.toList());
}
if(StringUtils.isNotBlank(mesLineAssistant.getLineCode())){
dtos = dtos.stream().filter(dto ->(dto.getLineCode().indexOf(mesLineAssistant.getProductName())>=0))
.collect(Collectors.toList());
}
return dtos;
}
/**生产日效率报表**/

@ -179,6 +179,7 @@ public class MesReportWorkServiceImpl implements IMesReportWorkService {
pTabs.setTitle("第"+i+"层工单信息");
mesReportWork.setParentOrder("0");
List<MesReportWork> liblist0 = mesReportWorkMapper.getReportList(mesReportWork);
pTabs.setLibList(liblist0);
pTabs.setRemark(liblist0.get(0).getRemark());
tabs.add(pTabs);

@ -97,12 +97,13 @@
<if test="carCode != null">
and be.department like concat('%',#{carCode},'%')
</if>
<!--
<if test="lineCode != null">
and be.sap_code like concat('%',#{lineCode},'%')
</if>
<if test="productName != null">
and pow.product_name like concat('%',#{productName},'%')
</if>
</if>-->
and pow.workorder_name is not null and pow.status in('w3','w4')
</select>
<select id="getHoursByOrderCode" resultType="java.math.BigDecimal">

@ -662,9 +662,14 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
pow.workorder_code_sap workorderCodeSap,
mrw.remark,mrw.report_code reportCode,
mrw.machine_code machineCode,
mrw.attr1,mrw.upload_status uploadStatus
mrw.attr1,mrw.upload_status uploadStatus,
qct.check_result checkResult
from mes_report_work mrw
left join pro_order_workorder pow on mrw.workorder_code = pow.workorder_code
left join qc_check_task qct on qct.check_type = 'checkTypeCPPC'
and qct.order_no = mrw.workorder_code
and mrw.batch = qct.income_batch_no
and qct.del_flag = '0'
where mrw.del_flag='0' and pow.del_flag = '0'
<if test='parentOrder=="0"'>
and mrw.workorder_code = #{workorderCode}

@ -55,6 +55,25 @@ public class QcInterface extends BaseEntity {
private String equipmentTypeCode;
private String checkType;
private String className;
private String defectSubclass;
public String getClassName() {
return className;
}
public void setClassName(String className) {
this.className = className;
}
public String getDefectSubclass() {
return defectSubclass;
}
public void setDefectSubclass(String defectSubclass) {
this.defectSubclass = defectSubclass;
}
public String getCheckType() {
return checkType;
}

@ -53,4 +53,8 @@ public interface QcInterfaceMapper {
QcInterface getProduceHz1(QcInterface qcInterface);
List<QcInterface> getCheckProjectsPieLL(QcInterface qcInterface);
List<QcInterface> getProduceNoOkList1(QcInterface qcInterface);
List<QcInterface> getCheckProjectsPie1(QcInterface qcInterface);
}

@ -95,7 +95,7 @@ public class QcInterfaceServiceImpl implements IQcInterfaceService {
String nowYMD = DateUtils.getDate();
qcInterface.setYmd(nowYMD);
List<QcInterface> dtos = qcInterfaceMapper.getCheckProjectsPie(qcInterface);
List<QcInterface> dtos = qcInterfaceMapper.getCheckProjectsPie1(qcInterface);
return dtos;
}
@ -233,9 +233,10 @@ public class QcInterfaceServiceImpl implements IQcInterfaceService {
@Override
public List<QcInterface> getProduceNoOkList(QcInterface qcInterface) {
DynamicDataSourceContextHolder.push(qcInterface.getFactoryCode());
String nowYMD = DateUtils.getDate();
qcInterface.setYmd(nowYMD);
List<QcInterface> dtos = qcInterfaceMapper.getProduceNoOkList(qcInterface);
// String nowYMD = DateUtils.getDate();
// qcInterface.setYmd(nowYMD);
// List<QcInterface> dtos = qcInterfaceMapper.getProduceNoOkList(qcInterface);
List<QcInterface> dtos = qcInterfaceMapper.getProduceNoOkList1(qcInterface);
return dtos;
}

@ -115,6 +115,28 @@
group by class_name
</if>
</select>
<select id="getCheckProjectsPie1" resultType="com.op.quality.domain.QcInterface">
select sum(noOk_quality) quality,
class_name projectName
FROM(
select
qctd.noOk_quality,
qdtc.class_name
from qc_check_task qct
left join qc_check_task_defect qctd on qctd.belong_to = qct.record_id
left join qc_defect_type_class qdtc on qctd.class_id = qdtc.id
where qct.check_type = 'checkTypeSCXJ' and qct.check_status = '2'
and (
CONVERT(varchar(10),qct.create_time, 120) >= SUBSTRING(#{productDateStart},0,11)
and
SUBSTRING(#{productDateEnd},0,11) >= CONVERT(varchar(10),qct.create_time, 120)
)
and qdtc.del_flag = '0' and qctd.del_flag = '0'
) t
group by class_name
</select>
<select id="getSupplierBadTOP5" resultType="com.op.quality.domain.QcInterface">
select top 5 t.* from (
select t0.noOkQuality*100/t0.batchs quality,t0.supplierName from(
@ -369,4 +391,26 @@
group by class_name
</if>
</select>
<select id="getProduceNoOkList1" resultType="com.op.quality.domain.QcInterface">
select qctd.rule_name projectName,
qct.check_man_name checkManName,
qctd.update_time checkTime,
qc.check_name checkName,
qdtc.class_name className,
qdt.defect_subclass defectSubclass
from qc_check_task_detail qctd
left join qc_check_task qct on qctd.belong_to = qct.record_id
left join qc_check_type qc on qc.order_code = qct.check_type and qc.del_flag = '0'
left join qc_defect_type_class qdtc on qdtc.id = qct.remark_code
left join qc_defect_type qdt on qdt.defect_id = qdtc.defect_id
where qct.type_code = #{typeCode} and qctd.status = 'N'
and (
CONVERT(varchar(10),qct.income_time, 120) >= SUBSTRING(#{productDateStart},0,11)
and
SUBSTRING(#{productDateEnd},0,11) >= CONVERT(varchar(10),qct.income_time, 120)
)
order by qctd.update_time desc
</select>
</mapper>

Loading…
Cancel
Save