package com.fzzy.async.fzzy61.impl; import com.fzzy.api.Constant; import com.fzzy.api.entity.Api1105; import com.fzzy.api.entity.Api1211; import com.fzzy.api.entity.ApiLog; import com.fzzy.api.service.ApiCommonService; import com.fzzy.api.service.ApiTriggerService; import com.fzzy.api.utils.ContextUtil; import com.fzzy.api.view.repository.Api1211Rep; import com.fzzy.api.view.repository.ApiLogRep; import com.fzzy.async.fzzy61.entity.Fz61DepotBookStore; import com.fzzy.async.fzzy61.repository.Fzzy61Sync1211Rep; import lombok.extern.slf4j.Slf4j; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Component; import java.util.Date; import java.util.List; /** * @author czt * 账面库存 */ @Slf4j @Component public class Fzzy61Sync1211 { @Autowired private Fzzy61Sync1211Rep fzzy61Sync1211Rep; @Autowired private ApiTriggerService apiTriggerService; @Autowired private Api1211Rep api1211Rep; @Autowired private ApiCommonService commonService; @Autowired private ApiLogRep apiLogRep; /** * 同步粮食库存 * * @param deptId * @param start * @param end */ public void syncData(String kqdm, String deptId, Date start, Date end) { log.info("-------------1211账面库存接口数据开始同步------------------"); //同步数据,只记录失败的信息 ApiLog apiLog = new ApiLog(); apiLog.setType(ApiLog.TYPE_SYNC); apiLog.setKqdm(deptId); apiLog.setUploadTime(new Date()); apiLog.setInteId(Constant.API_CODE_1208); apiLog.setStatus(99); apiLog.setId(ContextUtil.getUUID()); try { List list = fzzy61Sync1211Rep.listDepot(deptId, start, end); if (null == list || list.isEmpty()) { log.info("-------------没有获取到账面库存信息------------------"); return; } Api1211 apiData; Api1105 api1105; List api1211List; for (Fz61DepotBookStore fz61DepotBookStore : list) { //获取货位信息 api1105 = commonService.getApi1105Cache(fz61DepotBookStore.getDepotId()); if (null == api1105) { continue; } apiData = new Api1211(); apiData.setId(fz61DepotBookStore.getId()); apiData.setBizId(fz61DepotBookStore.getId()); apiData.setKqdm(kqdm); apiData.setHwdm(api1105.getHwdm()); //粮食品种 String mappingCode = apiTriggerService.getMappingCode(Constant.TRIGGER_P_LSPZ, fz61DepotBookStore.getLspzdm()); apiData.setLspzdm(mappingCode); //粮食性质 mappingCode = apiTriggerService.getMappingCode(Constant.TRIGGER_P_LSXZ, fz61DepotBookStore.getLsxzdm()); apiData.setLsxzdm(mappingCode); apiData.setNd(fz61DepotBookStore.getNd()); apiData.setYf(fz61DepotBookStore.getYf()); apiData.setQcsl(fz61DepotBookStore.getQcsl() == null ? 0.0 : fz61DepotBookStore.getQcsl()); apiData.setBqsrsl(fz61DepotBookStore.getBqsrsl() == null ? 0.0 : fz61DepotBookStore.getBqsrsl()); apiData.setBqzcsl(fz61DepotBookStore.getBqzcsl() == null ? 0.0 : fz61DepotBookStore.getBqzcsl()); apiData.setQmye(fz61DepotBookStore.getQmye() == null ? 0.0 : fz61DepotBookStore.getQmye()); //月结标志为空则默认给0-月结 if (null == fz61DepotBookStore.getYjbz()) { fz61DepotBookStore.setYjbz(0); } apiData.setYjbz(fz61DepotBookStore.getYjbz()); apiData.setYwrq(fz61DepotBookStore.getYwrq()); apiData.setZhgxsj(new Date()); api1211List = api1211Rep.getDataByBizId(apiData.getBizId()); if (null == api1211List || api1211List.isEmpty()) { apiData.setCzbz(Constant.CZBZ_I); } else { apiData.setCzbz(api1211List.get(0).getCzbz()); } //保存数据 api1211Rep.save(apiData); } } catch (Exception e) { log.error("---1211账面库存同步失败----{}", e.toString()); apiLog.setResult("同步失败:" + e.getMessage()); apiLogRep.save(apiLog); } } }