| package com.fzzy.async.fzzy30.impl; | 
|   | 
| import com.fzzy.api.Constant; | 
| import com.fzzy.api.entity.*; | 
| import com.fzzy.api.service.ApiCommonService; | 
| import com.fzzy.api.service.ApiTriggerService; | 
| import com.fzzy.api.utils.ContextUtil; | 
| import com.fzzy.api.view.repository.Api1102Rep; | 
| import com.fzzy.api.view.repository.Api1208Rep; | 
| import com.fzzy.api.view.repository.ApiLogRep; | 
| import com.fzzy.api.view.repository.GbAreaRep; | 
| import com.fzzy.async.fzzy30.entity.Depot; | 
| import com.fzzy.async.fzzy30.repository.FzzySync1208Rep; | 
| 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; | 
|   | 
| /** | 
|  * 粮食库存 | 
|  */ | 
| @Slf4j | 
| @Component | 
| public class Fzzy30Sync1208 { | 
|   | 
|     @Autowired | 
|     private FzzySync1208Rep fzzySync1208Rep; | 
|     @Autowired | 
|     private ApiTriggerService apiTriggerService; | 
|     @Autowired | 
|     private Api1208Rep api1208Rep; | 
|     @Autowired | 
|     private ApiCommonService commonService; | 
|     @Autowired | 
|     private Api1102Rep api1102Rep; | 
|     @Autowired | 
|     private GbAreaRep gbAreaRep; | 
|     @Autowired | 
|     private ApiLogRep apiLogRep; | 
|   | 
|     /** | 
|      * 同步粮食库存 | 
|      * | 
|      * @param deptId | 
|      * @param start | 
|      * @param end | 
|      */ | 
|     public void syncData(String kqdm, String deptId, Date start, Date end) { | 
|   | 
|         log.info("-------------1208接口数据开始同步------------------"); | 
|   | 
|         //同步数据,只记录失败的信息 | 
|         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<Depot> list = fzzySync1208Rep.listDepot(deptId); | 
|   | 
|             if (null == list || list.isEmpty()) { | 
|   | 
|                 log.info("-------------没有获取到粮食库存信息------------------"); | 
|   | 
|                 return; | 
|             } | 
|   | 
|             //根据库区代码获取单位代码 | 
|             Api1102 api1201 = api1102Rep.findById(kqdm).get(); | 
|   | 
|             Api1208 apiData; | 
|             Api1105 api1105; | 
|             List<GbArea> gbAreaList; | 
|             for (Depot sysData : list) { | 
|   | 
|                 //获取货位信息 | 
|                 api1105 = commonService.getApi1105Cache(sysData.getId()); | 
|                 if (null == api1105) { | 
|                     continue; | 
|                 } | 
|   | 
|                 apiData = new Api1208(); | 
|                 apiData.setHwdm(api1105.getHwdm()); | 
|   | 
|                 //粮食品种 | 
|                 String mappingCode = apiTriggerService.getMappingCode(Constant.TRIGGER_P_LSPZ, sysData.getFoodVariety()); | 
|                 apiData.setLspzdm(mappingCode); | 
|   | 
|                 //粮食性质 | 
|                 mappingCode = apiTriggerService.getMappingCode(Constant.TRIGGER_P_LSXZ, sysData.getFoodType()); | 
|                 apiData.setLsxzdm(mappingCode); | 
|   | 
|                 //粮食等级 | 
|                 mappingCode = apiTriggerService.getMappingCode(Constant.TRIGGER_P_LSDJ, sysData.getFoodLevel()); | 
|                 apiData.setLsdjdm(mappingCode); | 
|   | 
|                 apiData.setShnd(sysData.getFoodYear()); | 
|   | 
|                 //产地代码 | 
|                 gbAreaList = gbAreaRep.listByName("%" + sysData.getFoodLocation() + "%"); | 
|                 apiData.setCd(gbAreaList.get(0).getCode()); | 
|   | 
|                 apiData.setBgy(sysData.getStoreKeeperName()); | 
|                 apiData.setLqgsdwdm(api1201.getDwdm()); | 
|   | 
|                 //货位状态 | 
|                 mappingCode = apiTriggerService.getMappingCode(Constant.TRIGGER_P_HWZT, sysData.getDepotStatus()); | 
|                 apiData.setHwzt(mappingCode); | 
|   | 
|                 //国别 | 
|                 mappingCode = apiTriggerService.getMappingCode(Constant.TRIGGER_P_GB, sysData.getFoodLocation()); | 
|                 apiData.setGb(mappingCode); | 
|   | 
|                 apiData.setRcsj(sysData.getStoreDate()); | 
|                 apiData.setSjsl(sysData.getStorageReal()); | 
|                 apiData.setJjsl(sysData.getStorageReal()); | 
|   | 
|                 //操作标志及最后更新时间 | 
|                 apiData.setCzbz(Constant.CZBZ_U); | 
|                 apiData.setZhgxsj(new Date()); | 
|   | 
|                 //业务id、库区编码、同步时间 | 
|                 apiData.setBizId(sysData.getId()); | 
|                 apiData.setKqdm(kqdm); | 
|                 apiData.setSyncTime(new Date()); | 
|                 apiData.setId(api1105.getHwdm()); | 
|                 //保存数据 | 
|                 api1208Rep.delete(apiData); | 
|   | 
|                 api1208Rep.save(apiData); | 
|             } | 
|         } catch (Exception e) { | 
|             log.error("---同步失败----{}", e); | 
|             apiLog.setResult("同步失败:" + e.getMessage()); | 
|             apiLogRep.save(apiLog); | 
|         } | 
|     } | 
| } |