From a70bd1fd9fd10c3a8ae6cd83026be84b845ee0c9 Mon Sep 17 00:00:00 2001
From: czt <czt18638530771@163.com>
Date: 星期四, 01 八月 2024 15:22:42 +0800
Subject: [PATCH] 优化熏蒸备案数据同步

---
 src/main/java/com/fzzy/async/fzzy40/impl/Fzzy40Sync1023.java |  196 +++++++++++++++++++++++++++++++++----------------
 1 files changed, 132 insertions(+), 64 deletions(-)

diff --git a/src/main/java/com/fzzy/async/fzzy40/impl/Fzzy40Sync1023.java b/src/main/java/com/fzzy/async/fzzy40/impl/Fzzy40Sync1023.java
index aaedf5b..53a9aee 100644
--- a/src/main/java/com/fzzy/async/fzzy40/impl/Fzzy40Sync1023.java
+++ b/src/main/java/com/fzzy/async/fzzy40/impl/Fzzy40Sync1023.java
@@ -4,6 +4,8 @@
 import com.fzzy.api.Constant;
 import com.fzzy.api.data.PushProtocol;
 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.*;
 import com.fzzy.async.fzzy40.entity.*;
@@ -11,18 +13,17 @@
 import com.fzzy.async.fzzy40.repository.Fzzy40SyncDrugLogDtlRep;
 import com.fzzy.async.fzzy40.repository.Fzzy40SyncDrugLogPeopleRep;
 import com.fzzy.async.fzzy40.repository.Fzzy40SyncDrugLogWayRep;
-import com.fzzy.otherview.gd2022.dto.GdApi1023;
-import com.fzzy.otherview.gd2022.dto.GdApi1023Dtl;
-import com.fzzy.otherview.gd2022.dto.GdApi1023People;
-import com.fzzy.otherview.gd2022.dto.GdApi1023Way;
+import com.fzzy.push.gd2022.dto.Gd2022Api1023;
+import com.fzzy.push.gd2022.dto.Gd2022Api1023Dtl;
+import com.fzzy.push.gd2022.dto.Gd2022Api1023People;
+import com.fzzy.push.gd2022.dto.Gd2022Api1023Way;
 import com.fzzy.push.gd2022.ApiCodeConstant;
 import lombok.extern.slf4j.Slf4j;
-import org.apache.commons.lang.time.DateFormatUtils;
+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.text.DateFormat;
 import java.util.ArrayList;
 import java.util.Date;
 import java.util.List;
@@ -36,6 +37,12 @@
 @Component
 public class Fzzy40Sync1023 {
     @Autowired
+    private Api1101Rep api1101Rep;
+    @Autowired
+    private Api1102Rep api1102Rep;
+    @Autowired
+    private Api1105Rep api1105Rep;
+    @Autowired
     private Fzzy40Sync1023Rep fzzy40Sync1023Rep;
     @Autowired
     private Fzzy40SyncDrugLogPeopleRep drugLogPeopleRep;
@@ -46,7 +53,11 @@
     @Autowired
     private ApiLogRep apiLogRep;
     @Autowired
+    private ApiCommonService commonService;
+    @Autowired
     private ApiInfoDataRep apiInfoDataRep;
+    @Autowired
+    private ApiTriggerService apiTriggerService;
 
 
     /**
@@ -57,7 +68,7 @@
      * @param end
      */
     public void syncData(String kqdm, String deptId, Date start, Date end) {
-        log.info("-------------1023鎺ュ彛璁惧淇℃伅寮�濮嬪悓姝�------------------");
+        log.info("-------------1023鎺ュ彛鐔忚捀澶囨淇℃伅寮�濮嬪悓姝�------------------");
 
         //鍚屾鏁版嵁锛屽彧璁板綍澶辫触鐨勪俊鎭�
         ApiLog apiLog = new ApiLog();
@@ -68,93 +79,150 @@
         apiLog.setStatus(99);
         apiLog.setId(ContextUtil.getUUID());
         try {
-            List<Fz4DrugLogApply> list = fzzy40Sync1023Rep.listDrugLogApply(deptId);
+            List<Fz40DrugLogApply> list = fzzy40Sync1023Rep.listDrugLogApply(deptId);
 
             if (null == list || list.isEmpty()) {
                 log.info("-------------娌℃湁鑾峰彇鍒扮啅钂稿妗堜俊鎭�------------------");
                 return;
             }
-            List<GdApi1023Dtl> dtlList = new ArrayList<>();
-            List<GdApi1023Way> wayList = new ArrayList<>();
-            List<GdApi1023People> peopleList = new ArrayList<>();
-            for (Fz4DrugLogApply data : list) {
-                List<ApiInfoData> apiInfoList = apiInfoDataRep.getDataByInteAndData(ApiCodeConstant.API_1023, kqdm + DateFormatUtils.format(data.getTbrq(), "yyyyMMdd") + data.getXzbm());
-                if (apiInfoList.size() != 0) {
-                    continue;
+            List<Gd2022Api1023Dtl> dtlList;
+            List<Gd2022Api1023Way> wayList;
+            List<Gd2022Api1023People> peopleList;
+
+
+            Gd2022Api1023 GD2022Api1023;
+            Gd2022Api1023Dtl gd2022Api1023Dtl;
+            Gd2022Api1023Way gd2022Api1023Way;
+            Gd2022Api1023People gd2022Api1023People;
+
+            List<ApiInfoData> apiInfoList;
+            ApiInfoData infoData;
+            for (Fz40DrugLogApply data : list) {
+
+                GD2022Api1023 = new Gd2022Api1023();
+                BeanUtils.copyProperties(data, GD2022Api1023);
+                GD2022Api1023.setXzbm(data.getXzbm().substring(8));
+                GD2022Api1023.setKqdm(kqdm);
+                List<Api1102> api1102List = api1102Rep.findPushData(kqdm);
+                if (null != api1102List && api1102List.size() > 0) {
+                    GD2022Api1023.setKqmc(api1102List.get(0).getKqmc());
                 }
+
+                GD2022Api1023.setDwdm(kqdm.substring(0, 18));
+                List<Api1101> api1101List = api1101Rep.findPushData(kqdm);
+                if (null != api1101List && api1101List.size() > 0) {
+                    GD2022Api1023.setDwmc(api1101List.get(0).getDwmc());
+                }
+                GD2022Api1023.setYjmc(data.getDrugName());
+                GD2022Api1023.setYjlx(data.getDrugType());
+                GD2022Api1023.setLqrq(data.getLqsj());
+                GD2022Api1023.setZhgxsj(data.getUpdateTime());
+                if(data.getLqr().contains("銆�")){
+                    GD2022Api1023.setLqr(data.getLqr().replace("銆�", "|"));
+                }
+
                 //鍌ㄧ伯绮儏鏄庣粏琛�
-                String tbrq = "";
-                if (null != data.getTbrq()) {
-                    tbrq = DateFormatUtils.format(data.getTbrq(), "yyyyMMdd");
-                }
-                List<Fz40DrugLogDtl> dtls = drugLogDtlRep.listDrugLogDtl(kqdm + tbrq + data.getXzbm());
-                for (Fz40DrugLogDtl dtl : dtls) {
-                    GdApi1023Dtl gdApi1023Dtl = new GdApi1023Dtl();
-                    BeanUtils.copyProperties(dtl, gdApi1023Dtl);
-                    gdApi1023Dtl.setCfdm(dtl.getDepotId());
-                    gdApi1023Dtl.setLspzdm(dtl.getFoodVariety());
-                    gdApi1023Dtl.setLsxzdm(dtl.getFoodType());
-                    gdApi1023Dtl.setLsdjdm(dtl.getFoodLevel());
-                    gdApi1023Dtl.setLssl(dtl.getNumber());
-                    gdApi1023Dtl.setSf(dtl.getPerWet());
-                    gdApi1023Dtl.setZz(dtl.getPerImpurity());
-                    dtlList.add(gdApi1023Dtl);
-                }
-                List<Fz40DrugLogWay> ways = drugLogWayRep.listDrugLogWay(kqdm + tbrq + data.getXzbm());
-                for (Fz40DrugLogWay way : ways) {
-                    GdApi1023Way gdApi1023Way = new GdApi1023Way();
-                    BeanUtils.copyProperties(way, gdApi1023Way);
-                    wayList.add(gdApi1023Way);
-                }
-                List<Fz40DrugLogPeople> peoples = drugLogPeopleRep.listDrugLogPeople(kqdm + tbrq + data.getXzbm());
-                for (Fz40DrugLogPeople people : peoples) {
-                    GdApi1023People gdApi1023People = new GdApi1023People();
-                    BeanUtils.copyProperties(people, gdApi1023People);
-                    peopleList.add(gdApi1023People);
-
+                List<Fz40DrugLogDtl> dtls = drugLogDtlRep.listDrugLogDtl(data.getXzbm());
+                Api1105 api1105 = commonService.getApi1105Cache(data.getDepotId());
+                gd2022Api1023Dtl = new Gd2022Api1023Dtl();
+                BeanUtils.copyProperties(data, gd2022Api1023Dtl);
+                if (null != api1105) {
+                    gd2022Api1023Dtl.setCfmc(api1105.getHwmc());
+                    gd2022Api1023Dtl.setCfdm(api1105.getHwdm().substring(0, 25));
                 }
 
-                GdApi1023 gdApi1023 = new GdApi1023();
-                BeanUtils.copyProperties(data, gdApi1023);
-                gdApi1023.setXzbm(data.getXzbm());
-                gdApi1023.setKqdm(kqdm);
-                gdApi1023.setDwdm(kqdm.substring(0, 18));
-                gdApi1023.setYjmc(data.getDrugName());
-                gdApi1023.setYjlx(data.getDrugType());
-                gdApi1023.setZhgxsj(data.getUpdateTime());
+                //绮鍝佺
+                String mappingCode = apiTriggerService.getMappingCode(Constant.TRIGGER_P_LSPZ, data.getFoodVariety().substring(0, 3));
+                gd2022Api1023Dtl.setLspzdm(mappingCode);
+                gd2022Api1023Dtl.setLsxzdm(data.getFoodType());
+                gd2022Api1023Dtl.setLsdjdm(data.getFoodLevel());
+                gd2022Api1023Dtl.setLssl(data.getNumber());
+                gd2022Api1023Dtl.setSf(data.getPerWet());
+                gd2022Api1023Dtl.setZz(data.getPerImpurity());
 
-                gdApi1023.setDtls(dtlList);
-                gdApi1023.setWays(wayList);
-                gdApi1023.setPeoples(peopleList);
 
+                dtlList = new ArrayList<>();
+                dtlList.add(gd2022Api1023Dtl);
+                GD2022Api1023.setDtls(dtlList);
+//                if (null != dtls && dtls.size() > 0) {
+//                    dtlList = new ArrayList<>();
+//                    for (Fz40DrugLogDtl dtl : dtls) {
+//                        gdApi1023Dtl = new GdApi1023Dtl();
+//                        BeanUtils.copyProperties(dtl, gdApi1023Dtl);
+//                        gdApi1023Dtl.setCfdm(dtl.getDepotId());
+//                        gdApi1023Dtl.setLspzdm(dtl.getFoodVariety());
+//                        gdApi1023Dtl.setLsxzdm(dtl.getFoodType());
+//                        gdApi1023Dtl.setLsdjdm(dtl.getFoodLevel());
+//                        gdApi1023Dtl.setLssl(dtl.getNumber());
+//                        gdApi1023Dtl.setSf(dtl.getPerWet());
+//                        gdApi1023Dtl.setZz(dtl.getPerImpurity());
+//                        dtlList.add(gdApi1023Dtl);
+//                    }
+//                    gdApi1023.setDtls(dtlList);
+//                }
+
+
+                gd2022Api1023Way = new Gd2022Api1023Way();
+                BeanUtils.copyProperties(data, gd2022Api1023Way);
+                wayList = new ArrayList<>();
+                wayList.add(gd2022Api1023Way);
+                GD2022Api1023.setWays(wayList);
+//                List<Fz40DrugLogWay> ways = drugLogWayRep.listDrugLogWay(data.getXzbm());
+//                if (null != ways && ways.size() > 0) {
+//                    wayList = new ArrayList<>();
+//                    for (Fz40DrugLogWay way : ways) {
+//                        gdApi1023Way = new GdApi1023Way();
+//                        BeanUtils.copyProperties(way, gdApi1023Way);
+//                        wayList.add(gdApi1023Way);
+//                    }
+//                    gdApi1023.setWays(wayList);
+//                }
+
+                List<Fz40DrugLogPeople> peoples = drugLogPeopleRep.listDrugLogPeople(data.getXzbm());
+                if (null != peoples && peoples.size() > 0) {
+                    peopleList = new ArrayList<>();
+                    for (Fz40DrugLogPeople people : peoples) {
+                        gd2022Api1023People = new Gd2022Api1023People();
+                        BeanUtils.copyProperties(people, gd2022Api1023People);
+                        gd2022Api1023People.setXm(people.getMx());
+                        if(StringUtils.isEmpty(gd2022Api1023People.getZyzg())){
+                            gd2022Api1023People.setZyzg("楂樼骇");
+                        }
+
+                        peopleList.add(gd2022Api1023People);
+                    }
+                    GD2022Api1023.setPeoples(peopleList);
+                }
                 //鎸佷箙鍖栦繚瀛橈紝鍗曠嫭瀛樺叆闈炲浗鏍囨帴鍙h〃
-                ApiInfoData infoData = new ApiInfoData();
-                infoData.setId(ContextUtil.getUUID());
+                infoData = new ApiInfoData();
+
                 infoData.setKqdm(kqdm);
                 infoData.setInteType(Constant.API_CATEGORY_13);
                 infoData.setInteId(ApiCodeConstant.API_1023);
                 infoData.setBizType(PushProtocol.SB_GD_2022.getCode());
                 infoData.setUpdateTime(new Date());
-                infoData.setDataId(kqdm + DateFormatUtils.format(data.getTbrq(), "yyyyMMdd") + data.getXzbm());
+                infoData.setDataId(data.getXzbm());
+                infoData.setId(data.getXzbm());
+                apiInfoList = apiInfoDataRep.getDataByInteAndData(ApiCodeConstant.API_1023, data.getXzbm(), kqdm);
 
                 if (null == apiInfoList || apiInfoList.isEmpty()) {
-                    gdApi1023.setCzbz(Constant.CZBZ_I);
+                    GD2022Api1023.setCzbz(Constant.CZBZ_I);
                     infoData.setCzbz(Constant.CZBZ_I);
                 } else {
-                    gdApi1023.setCzbz(apiInfoList.get(0).getCzbz());
+                    GD2022Api1023.setCzbz(apiInfoList.get(0).getCzbz());
                     infoData.setCzbz(apiInfoList.get(0).getCzbz());
                 }
 
-                infoData.setData(JSON.toJSONString(gdApi1023));
+                infoData.setData(JSON.toJSONString(GD2022Api1023));
 
                 //淇濆瓨鏁版嵁
                 apiInfoDataRep.save(infoData);
-                log.info("1023---鍚屾鏁版嵁锛歿}", gdApi1023.toString());
+                log.info("1023---鍚屾鏁版嵁锛歿}", GD2022Api1023.toString());
             }
 
         } catch (Exception e) {
-            log.error("---璁惧淇℃伅鍚屾鎵ц澶辫触----{}", e.toString());
-            apiLog.setResult("璁惧淇℃伅鍚屾鎵ц澶辫触锛�" + e.getMessage());
+            log.error("---鐔忚捀澶囨鍚屾鎵ц澶辫触----{}", e.toString());
+            apiLog.setResult("鐔忚捀澶囨淇℃伅鍚屾鎵ц澶辫触锛�" + e.getMessage());
             apiLogRep.save(apiLog);
         }
     }

--
Gitblit v1.9.3