package com.fzzy.async.fzzy40.impl; import com.fzzy.api.Constant; import com.fzzy.api.entity.*; import com.fzzy.api.service.ApiCommonService; import com.fzzy.api.utils.ContextUtil; import com.fzzy.api.view.repository.Api1303Rep; import com.fzzy.api.view.repository.Api1306Rep; import com.fzzy.api.view.repository.ApiLogRep; import com.fzzy.async.fzzy40.entity.Fz40DrugLog; import com.fzzy.async.fzzy40.repository.Fzzy40Sync1306Rep; import lombok.extern.slf4j.Slf4j; import org.apache.commons.lang.StringUtils; import org.springframework.beans.BeanUtils; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Component; import java.util.Date; import java.util.List; /** * 熏蒸作业数据同步 * * @author czt * @date 2022-09-08 09:51 */ @Slf4j @Component public class Fzzy40Sync1306 { @Autowired private Fzzy40Sync1306Rep fzzySync1306Rep; @Autowired private ApiCommonService commonService; @Autowired private Api1306Rep api1306Rep; @Autowired private Api1303Rep api1303Rep; @Autowired private ApiLogRep apiLogRep; /** * 同步并封装保存熏蒸数据 * * @param deptId 系统对应库区编码 * @param start 起始时间 * @param end 截止时间 */ public void syncData(String kqdm, String deptId, Date start, Date end) { log.info("-------------1306接口数据开始同步------------------"); //同步数据,只记录失败的信息 ApiLog apiLog = new ApiLog(); apiLog.setType(ApiLog.TYPE_SYNC); apiLog.setKqdm(deptId); apiLog.setUploadTime(new Date()); apiLog.setInteId(Constant.API_CODE_1306); apiLog.setStatus(99); apiLog.setId(ContextUtil.getUUID()); try { List list = fzzySync1306Rep.findByReceiveDate(start, end); if (null == list || list.isEmpty()) { return; } Api1306 api1306; Api1105 api1105; List api1306List; List api1303List; for (Fz40DrugLog fz40DrugLog : list) { //获取货位信息 api1105 = commonService.getApi1105Cache(fz40DrugLog.getDepotId()); if (null == api1105) { continue; } api1306 = new Api1306(); BeanUtils.copyProperties(fz40DrugLog, api1306); api1306.setXzzydh(api1105.getHwdm().substring(0,25) + fz40DrugLog.getId()); api1306.setCfdm(api1105.getHwdm().substring(0,25)); api1306.setXzkssj(fz40DrugLog.getStart()); api1306.setXzjssj(fz40DrugLog.getEnd()); //设置虫害检测单号 api1306.setHcjcdh(api1105.getHwdm() + fz40DrugLog.getPestBatchId()); api1303List = api1303Rep.getDataByBizId(fz40DrugLog.getPestBatchId()); if (null != api1303List && api1303List.size() > 0) { api1306.setHcjcdh(api1303List.get(0).getHcjcdh()); } api1306.setDjcxz(fz40DrugLog.getNum()); api1306.setCgxzfs(fz40DrugLog.getMode()); api1306.setHlxzfs(fz40DrugLog.getRecirMode()); api1306.setYjmc(fz40DrugLog.getDrugName()); api1306.setNd(fz40DrugLog.getConcentration()); api1306.setLddwyyl(fz40DrugLog.getGrainDose()); api1306.setKjdwyyl(fz40DrugLog.getSpaceDose()); api1306.setSyff(StringUtils.isEmpty(fz40DrugLog.getSyff())?"0":fz40DrugLog.getSyff()); api1306.setZyyl(fz40DrugLog.getDose()); api1306.setSqrq(fz40DrugLog.getVentilateTime()); api1306.setSqff(fz40DrugLog.getVentilateMethod()); api1306.setSqjsslhqnd(fz40DrugLog.getAfterPh3()); api1306.setXzxgpj(fz40DrugLog.getEvaluate()); api1306.setZhgxsj(new Date()); api1306.setHwdm(api1105.getHwdm()); api1306.setKqdm(kqdm); api1306.setBizId(fz40DrugLog.getId()); api1306List = api1306Rep.getDataById(api1306.getXzzydh()); if (null == api1306List || api1306List.isEmpty()) { api1306.setCzbz(Constant.CZBZ_I); } else { api1306.setCzbz(api1306List.get(0).getCzbz()); } api1306Rep.save(api1306); } } catch (Exception e) { log.error("---同步失败----{}", e); apiLog.setResult("同步失败:" + e.getMessage()); apiLogRep.save(apiLog); } } }