修正默认参与比较值逻辑,增加不参与误差比较状态
This commit is contained in:
@@ -38,6 +38,11 @@ public class ErrDtlsCheckDataVO implements Serializable {
|
||||
*/
|
||||
private String phase;
|
||||
|
||||
/**
|
||||
* 默认参与比较值(4.不参与值 5.不参与误差比较)
|
||||
*/
|
||||
private Integer isQualified;
|
||||
|
||||
/**
|
||||
* 误差体系
|
||||
*/
|
||||
|
||||
@@ -94,34 +94,38 @@ public class PqErrSysDtlsServiceImpl extends ServiceImpl<PqErrSysDtlsMapper, PqE
|
||||
|
||||
@Override
|
||||
public List<ErrDtlsCheckDataVO> listByPqErrSysIdAndTypes(PqErrSysParam.DetectionParam param) {
|
||||
List<ErrDtlsCheckDataVO> info=new ArrayList<>();
|
||||
List<ErrDtlsCheckDataVO> info = new ArrayList<>();
|
||||
PqScriptCheckDataParam checkDataParam = new PqScriptCheckDataParam();
|
||||
checkDataParam.setScriptId(param.getScriptId());
|
||||
checkDataParam.setIndex(param.getIndex());
|
||||
//获取检测脚本中所有装置下发的测试项
|
||||
List<PqScriptCheckData> list = pqScriptCheckDataService.listCheckDataCode(checkDataParam);
|
||||
Boolean isValueType = pqScriptMapper.selectScriptIsValueType(param.getScriptId());
|
||||
|
||||
List<String> valueType = list.stream().filter(x->x.getErrorFlag()!=0).map(PqScriptCheckData::getValueType).collect(Collectors.toList());
|
||||
Map<String, List<PqErrSysDtls>> errMap =new HashMap<>(3);
|
||||
if(CollUtil.isNotEmpty(valueType)){
|
||||
Map<String, Integer> valueType = list.stream().collect(Collectors.toMap(PqScriptCheckData::getValueType, PqScriptCheckData::getErrorFlag,
|
||||
(key1, key2) -> key1));
|
||||
|
||||
//获取误差体系
|
||||
Map<String, List<PqErrSysDtls>> errMap = new HashMap<>(3);
|
||||
if (CollUtil.isNotEmpty(valueType)) {
|
||||
List<PqErrSysDtls> errSysDtls = this.list(new MPJLambdaWrapper<PqErrSysDtls>().selectAll(PqErrSysDtls.class)
|
||||
.selectAll(PqErrSysDtls.class)
|
||||
.selectAs(DictTree::getCode, PqErrSysDtls::getScriptCode)
|
||||
.leftJoin(DictTree.class, DictTree::getId, PqErrSysDtls::getScriptType)
|
||||
.eq(PqErrSysDtls::getErrorSysId, param.getErrorSysId())
|
||||
.in(PqErrSysDtls::getScriptType, valueType)
|
||||
.in(PqErrSysDtls::getScriptType, valueType.keySet())
|
||||
);
|
||||
errMap= errSysDtls.stream().collect(Collectors.groupingBy(PqErrSysDtls::getScriptType));
|
||||
errMap = errSysDtls.stream().collect(Collectors.groupingBy(PqErrSysDtls::getScriptType));
|
||||
}
|
||||
ErrDtlsCheckDataVO dataVO;
|
||||
for (PqScriptCheckData script : list) {
|
||||
dataVO=new ErrDtlsCheckDataVO();
|
||||
dataVO = new ErrDtlsCheckDataVO();
|
||||
dataVO.setCheckDataId(script.getScriptId());
|
||||
dataVO.setValueTypeCode(script.getValueTypeCode());
|
||||
dataVO.setValueType(script.getValueType());
|
||||
dataVO.setValue(script.getValue());
|
||||
dataVO.setPhase(script.getPhase());
|
||||
if(isValueType){
|
||||
if (isValueType) {
|
||||
if (DetectionCodeEnum.VRMS.getCode().equals(script.getValueTypeCode())) {
|
||||
BigDecimal volValue = new BigDecimal(script.getValue());
|
||||
BigDecimal result = volValue.multiply(new BigDecimal(param.getUn().toString()))
|
||||
@@ -135,9 +139,17 @@ public class PqErrSysDtlsServiceImpl extends ServiceImpl<PqErrSysDtlsMapper, PqE
|
||||
dataVO.setValue(result.doubleValue());
|
||||
}
|
||||
}
|
||||
|
||||
if(errMap.containsKey(script.getValueType())){
|
||||
dataVO.setErrSysDtls(errMap.get(script.getValueType()));
|
||||
if (valueType.containsKey(script.getValueType())) {
|
||||
//默认值4.无法处理 5.不参与误差比较
|
||||
Integer i = valueType.get(script.getValueType());
|
||||
if (i == 1) {
|
||||
dataVO.setIsQualified(4);
|
||||
if (errMap.containsKey(script.getValueType())) {
|
||||
dataVO.setErrSysDtls(errMap.get(script.getValueType()));
|
||||
}
|
||||
} else {
|
||||
dataVO.setIsQualified(5);
|
||||
}
|
||||
}
|
||||
info.add(dataVO);
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user