From 132cb0d089c7734f3eb3e858bd741fbc60dbdc9d Mon Sep 17 00:00:00 2001
From: 陈昶聿 <chychen@nbjetron.com>
Date: 星期二, 20 一月 2026 16:46:25 +0800
Subject: [PATCH] 【丽水】获取随访统计比例 查询优化

---
 smartor/src/main/java/com/smartor/service/impl/PatArchiveServiceImpl.java |  182 ++++++++++++++++++++++++++++++++++++++++++---
 1 files changed, 169 insertions(+), 13 deletions(-)

diff --git a/smartor/src/main/java/com/smartor/service/impl/PatArchiveServiceImpl.java b/smartor/src/main/java/com/smartor/service/impl/PatArchiveServiceImpl.java
index 09307bc..f9a5cb8 100644
--- a/smartor/src/main/java/com/smartor/service/impl/PatArchiveServiceImpl.java
+++ b/smartor/src/main/java/com/smartor/service/impl/PatArchiveServiceImpl.java
@@ -7,10 +7,7 @@
 import com.ruoyi.common.utils.DtoConversionUtils;
 import com.ruoyi.common.utils.StringUtils;
 import com.smartor.domain.*;
-import com.smartor.mapper.BaseTagMapper;
-import com.smartor.mapper.PatArchiveMapper;
-import com.smartor.mapper.PatArchivetagMapper;
-import com.smartor.mapper.ServiceSubtaskMapper;
+import com.smartor.mapper.*;
 import com.smartor.service.IPatArchiveService;
 import com.smartor.service.IPatMedInhospService;
 import com.smartor.service.IPatMedOuthospService;
@@ -62,13 +59,15 @@
     private IPatMedInhospService patMedInhospService;
 
     @Autowired
-    private IPatMedOuthospService patMedOuthospService;
+    private PatArchivecontactMapper patArchivecontactMapper;
 
     @Autowired
     private IPatMedPhysicalService patMedPhysicalService;
 
     @Autowired
     private RedisCache redisCache;
+    @Autowired
+    private PatArchivetagServiceImpl patArchivetagServiceImpl;
 
 
     /**
@@ -106,6 +105,16 @@
         patArchive.setCreateTime(DateUtils.getNowDate());
         patArchiveMapper.insertPatArchiveSingle(patArchive);
         return patArchive.getId().intValue();
+    }
+
+    @Transactional(rollbackFor = Exception.class)
+    @Override
+    public Boolean updateArchive(PatArchive patArchive) {
+        int i = patArchiveMapper.updatePatArchive(patArchive);
+        if (i != 1) {
+            return false;
+        }
+        return true;
     }
 
     @Transactional(rollbackFor = Exception.class)
@@ -149,6 +158,33 @@
             //淇敼
             patArchiveVO.setIsoperation(2);
             patArchiveMapper.updatePatArchive(patArchive);
+            if (StringUtils.isNotEmpty(patArchive.getNotrequiredFlag()) && patArchive.getNotrequiredFlag().equals("1")) {
+                //涓嶉渶瑕佹湇鍔′簡锛岄渶瑕侀�氳繃patid鍜宻endstate=2鎴栬�卻endstate=1鍘绘煡璇竴涓嬶紝service_subtask閲屾槸鍚︽湁姝e湪鎵ц鐨勪换鍔★紝鏈夌殑璇濓紝绔嬪嵆鍋滀簡
+                ServiceSubtaskVO serviceSubtaskVO = new ServiceSubtaskVO();
+                serviceSubtaskVO.setPatid(patArchive.getId());
+                serviceSubtaskVO.setSendstate(2L);
+                List<ServiceSubtask> serviceSubtaskList = serviceSubtaskMapper.selectServiceSubtaskList(serviceSubtaskVO);
+                serviceSubtaskVO.setSendstate(1L);
+                List<ServiceSubtask> serviceSubtaskList1 = serviceSubtaskMapper.selectServiceSubtaskList(serviceSubtaskVO);
+                if (CollectionUtils.isNotEmpty(serviceSubtaskList)) {
+                    if (CollectionUtils.isNotEmpty(serviceSubtaskList1)) serviceSubtaskList.addAll(serviceSubtaskList1);
+                } else {
+                    if (CollectionUtils.isNotEmpty(serviceSubtaskList1)) serviceSubtaskList = serviceSubtaskList1;
+                }
+                //鍘籸edis涓紝鏌ヨ鏄惁鏈塻ubid锛屾湁鐨勮瘽绉婚櫎cache-exist
+                if (CollectionUtils.isNotEmpty(serviceSubtaskList)) {
+                    for (ServiceSubtask serviceSubtask : serviceSubtaskList) {
+                        log.info("闇�瑕佺Щ闄ょ殑subId涓猴細{}", serviceSubtask.getId().toString());
+                        serviceSubtaskMapper.deleteServiceSubtaskById(serviceSubtask.getId());
+                        redisCache.removeElementFromList("cache-exist", serviceSubtask.getId().toString());
+                        redisCache.removeElementFromList("cache-0", serviceSubtask.getId().toString());
+                        redisCache.removeElementFromList("cache-1", serviceSubtask.getId().toString());
+                        redisCache.removeElementFromList("cache-2", serviceSubtask.getId().toString());
+                        redisCache.removeElementFromList("cache-3", serviceSubtask.getId().toString());
+                        redisCache.removeElementFromList("cache-4", serviceSubtask.getId().toString());
+                    }
+                }
+            }
         }
 
         if (CollectionUtils.isNotEmpty(patArchiveVO.getTagList())) {
@@ -157,6 +193,22 @@
                 patArchivetag.setGuid(patArchiveVO.getGuid());
                 patArchivetag.setOrgid(patArchiveVO.getOrgid());
                 if (patArchivetag.getIsoperation() != null && patArchivetag.getIsoperation() == 1 || patArchivetag.getIsoperation() == null && patArchiveVO.getIsoperation() == 1) {
+                    //鍒ゆ柇涓�涓媌ase_tag閲屾槸涓嶆槸瀛樺湪锛屽鏋滀笉瀛樺湪锛屽厛鏂板
+                    BaseTag baseTag = new BaseTag();
+                    baseTag.setTagname(patArchivetag.getTagname().trim());
+                    List<BaseTag> baseTags = baseTagMapper.selectBaseTagListByTagname(baseTag);
+                    if (CollectionUtils.isEmpty(baseTags)) {
+                        //鍏堢粰鏀惧埌鏈垎绫讳腑
+                        baseTag.setTagcategoryid(6L);
+                        baseTag.setOrgid(patArchiveVO.getOrgid());
+                        baseTag.setDelFlag("0");
+                        baseTag.setUpdateTime(new Date());
+                        baseTag.setCreateTime(new Date());
+                        baseTagMapper.insertBaseTag(baseTag);
+                        patArchivetag.setTagid(baseTag.getTagid());
+                    } else {
+                        patArchivetag.setTagid(baseTags.get(0).getTagid());
+                    }
                     //鏂板
                     patArchivetag.setUpdateBy(null);
                     patArchivetag.setCreateTime(new Date());
@@ -229,6 +281,13 @@
             List<PatArchiveOthreInfo> patArchives3 = patArchiveMapper.selectPatArchiveInfoByPhysical(patArchiveReq);
             if (CollectionUtils.isNotEmpty(patArchives3)) {
                 patArchiveList.addAll(patArchives3);
+            }
+        } else if (patArchiveReq.getAllhosp() != null && patArchiveReq.getAllhosp() == 4) {
+            //  鏌ョ湅浣忛櫌  1  鏌ョ湅闂ㄨ瘖  2   鏌ョ湅浣撴  3   鏌ョ湅鍑洪櫌 4
+            patArchiveReq.setCry(1);
+            List<PatArchiveOthreInfo> patArchives1 = patArchiveMapper.selectPatArchiveInfoByInhospQC(patArchiveReq);
+            if (CollectionUtils.isNotEmpty(patArchives1)) {
+                patArchiveList.addAll(patArchives1);
             }
         }
 
@@ -508,7 +567,12 @@
     @Override
     public List<PatArchive> patInfoByContion(PatArchiveReq patArchive) {
         List<PatArchive> patArchives = new ArrayList<>();
-
+        if (ObjectUtils.isNotEmpty(patArchive.getPageNum()) && ObjectUtils.isNotEmpty(patArchive.getPageSize())) {
+            patArchive.setPn((patArchive.getPageNum() - 1) * patArchive.getPageSize());
+            patArchive.setPs(patArchive.getPageSize());
+            patArchive.setPageNum(null);
+            patArchive.setPageSize(null);
+        }
         //鏍规嵁鏉′欢鑾峰彇鎮h�呬俊鎭�
 //        List<PatArchive> patArchiveList = patArchiveMapper.patInfoByContion(patArchive);
         List<PatArchiveOthreInfo> patArchiveList = new ArrayList<>();
@@ -538,6 +602,13 @@
             if (CollectionUtils.isNotEmpty(patArchives3)) {
                 patArchiveList.addAll(patArchives3);
             }
+        } else if (patArchive.getAllhosp() != null && patArchive.getAllhosp() == 4) {
+            //  鏌ョ湅浣忛櫌  1  鏌ョ湅闂ㄨ瘖  2   鏌ョ湅浣撴  3   鏌ョ湅鍑洪櫌 4
+            patArchive.setCry(1);
+            List<PatArchiveOthreInfo> patArchives1 = patArchiveMapper.selectPatArchiveInfoByInhospQC(patArchive);
+            if (CollectionUtils.isNotEmpty(patArchives1)) {
+                patArchiveList.addAll(patArchives1);
+            }
         }
 
         //鏍规嵁鎮h�匢D杩涜鍒嗙粍
@@ -555,15 +626,35 @@
                 }
                 //灏嗘煡鍑虹殑tag锛屾斁鍒皃atArchive1閲岀殑TagList涓�
                 PatArchivetag patArchivetag = new PatArchivetag();
-                patArchivetag.setTagname(list.get(i).getTag());
-                patArchivetag.setTagid(list.get(i).getTagid());
-                stringList.add(patArchivetag);
+                if (StringUtils.isNotEmpty(list.get(i).getTag()) && ObjectUtils.isNotEmpty(list.get(i).getTagid())) {
+                    patArchivetag.setTagname(list.get(i).getTag());
+                    patArchivetag.setTagid(list.get(i).getTagid());
+                    stringList.add(patArchivetag);
+                }
             }
             patArchive1.setTagList(stringList.stream().collect(Collectors.toList()));
             patArchives.add(patArchive1);
         }
+        //灏唒atArchives閲岀殑tagList鏀惧埌patArchiveList鐨勫璞¢噷
+        for (PatArchiveOthreInfo poi : patArchiveList) {
+            for (PatArchive pa : patArchives) {
+                if (poi.getId() == pa.getId()) {
+                    poi.setTagList(pa.getTagList());
 
-        return patArchives;
+                }
+            }
+        }
+
+        List<PatArchive> patArchiveList1 = DtoConversionUtils.sourceToTarget(patArchiveList, PatArchive.class);
+        //缁欐偅鑰呰仈绯讳汉璧嬪��
+//        for (PatArchive pa : patArchives) {
+        for (PatArchive pa : patArchiveList1) {
+            PatArchivecontact patArchivecontact = new PatArchivecontact();
+            patArchivecontact.setPatid(pa.getId());
+            pa.setPatArchivecontactList(patArchivecontactMapper.selectPatArchivecontactList(patArchivecontact));
+        }
+
+        return patArchiveList1;
     }
 
     @Override
@@ -681,26 +772,91 @@
 
         List<PatArchiveOthreInfo> patArchiveList = new ArrayList<>();
         if (patArchiveReq.getAllhosp() != null && patArchiveReq.getAllhosp() == 1) {
-            //  鏌ョ湅浣忛櫌  1  鏌ョ湅闂ㄨ瘖  2   鏌ョ湅浣撴  3
+            //  鏌ョ湅浣忛櫌  1  鏌ョ湅闂ㄨ瘖  2   鏌ョ湅浣撴  3    鏌ョ湅鍑洪櫌 4
+            patArchiveReq.setCry(0);
             List<PatArchiveOthreInfo> patArchives1 = patArchiveMapper.selectPatArchiveInfoByInhospQC(patArchiveReq);
             if (CollectionUtils.isNotEmpty(patArchives1)) {
                 patArchiveList.addAll(patArchives1);
             }
         } else if (patArchiveReq.getAllhosp() != null && patArchiveReq.getAllhosp() == 2) {
-            // 鏌ョ湅浣忛櫌  1  鏌ョ湅闂ㄨ瘖  2   鏌ョ湅浣撴  3
+            // 鏌ョ湅浣忛櫌  1  鏌ョ湅闂ㄨ瘖  2   鏌ョ湅浣撴  3 鏌ョ湅鍑洪櫌 4
             List<PatArchiveOthreInfo> patArchives2 = patArchiveMapper.selectPatArchiveInfoByOuthospQC(patArchiveReq);
             if (CollectionUtils.isNotEmpty(patArchives2)) {
                 patArchiveList.addAll(patArchives2);
             }
         } else if (patArchiveReq.getAllhosp() != null && patArchiveReq.getAllhosp() == 3) {
-            //  鏌ョ湅浣忛櫌  1  鏌ョ湅闂ㄨ瘖  2   鏌ョ湅浣撴  3
+            //  鏌ョ湅浣忛櫌  1  鏌ョ湅闂ㄨ瘖  2   鏌ョ湅浣撴  3 鏌ョ湅鍑洪櫌 4
             List<PatArchiveOthreInfo> patArchives3 = patArchiveMapper.selectPatArchiveInfoByPhysicalQC(patArchiveReq);
             if (CollectionUtils.isNotEmpty(patArchives3)) {
                 patArchiveList.addAll(patArchives3);
             }
+
+        } else if (patArchiveReq.getAllhosp() != null && patArchiveReq.getAllhosp() == 4) {
+            //  鏌ョ湅浣忛櫌  1  鏌ョ湅闂ㄨ瘖  2   鏌ョ湅浣撴  3   鏌ョ湅鍑洪櫌 4
+            patArchiveReq.setCry(1);
+            log.info("--------鏌ョ湅鍑洪櫌鐨勫叆鍙傚�间负锛歿}", patArchiveReq);
+            List<PatArchiveOthreInfo> patArchives1 = patArchiveMapper.selectPatArchiveInfoByInhospQC(patArchiveReq);
+            log.info("--------鏌ョ湅鍑洪櫌鐨勮繑鍙傚�间负锛歿}", patArchives1.size());
+            if (CollectionUtils.isNotEmpty(patArchives1)) {
+                patArchiveList.addAll(patArchives1);
+            }
         }
+//        //鏌ヨtagName
+//        List<Long> patIds = patArchiveList.stream().map(PatArchiveOthreInfo::getId).distinct().collect(Collectors.toList());
+//        Map<Long, String> patTagMap= patArchivetagMapper.getTagsByPatIds(patArchiveReq.getOrgid(),patIds);
+//        //瑁呴厤tagName
+//        if(ObjectUtils.isNotEmpty(patTagMap)){
+//            patArchiveList.forEach(patArchiveOthreInfo -> {
+//                String tagName = patTagMap.get(patArchiveOthreInfo.getId());
+//                if(StringUtils.isNotEmpty(tagName)){
+//                    patArchiveOthreInfo.setTag(tagName);
+//                }
+//            });
+//        }
 
         return patArchiveList;
     }
+
+    /**
+     * 鑾峰彇鎮h�呬俊鎭�(鍘婚噸)
+     *
+     * @param patArchiveReq
+     * @return
+     */
+//    @Override
+    /**
+     * 鑾峰彇鎮h�呬俊鎭�绘暟锛堝幓閲嶏級
+     *
+     * @param patArchiveReq
+     * @return
+     */
+    @Override
+    public Long getPatientInfoQCCount(PatArchiveReq patArchiveReq) {
+        if (CollectionUtils.isEmpty(patArchiveReq.getLeavehospitaldistrictcodes()) || patArchiveReq.getLeavehospitaldistrictcodes().size() == 0) {
+            patArchiveReq.setLeavehospitaldistrictcodes(null);
+        }
+        if (CollectionUtils.isEmpty(patArchiveReq.getLeaveldeptcodes()) || patArchiveReq.getLeaveldeptcodes().size() == 0) {
+            patArchiveReq.setLeaveldeptcodes(null);
+        }
+
+        Long count = 0L;
+        if (patArchiveReq.getAllhosp() != null && patArchiveReq.getAllhosp() == 1) {
+            //  鏌ョ湅浣忛櫌  1  鏌ョ湅闂ㄨ瘖  2   鏌ョ湅浣撴  3    鏌ョ湅鍑洪櫌 4
+            patArchiveReq.setCry(0);
+            count = patArchiveMapper.countPatArchiveInfoByInhospQC(patArchiveReq);
+        } else if (patArchiveReq.getAllhosp() != null && patArchiveReq.getAllhosp() == 2) {
+            // 鏌ョ湅浣忛櫌  1  鏌ョ湅闂ㄨ瘖  2   鏌ョ湅浣撴  3 鏌ョ湅鍑洪櫌 4
+            count = patArchiveMapper.countPatArchiveInfoByOuthospQC(patArchiveReq);
+        } else if (patArchiveReq.getAllhosp() != null && patArchiveReq.getAllhosp() == 3) {
+            //  鏌ョ湅浣忛櫌  1  鏌ョ湅闂ㄨ瘖  2   鏌ョ湅浣撴  3 鏌ョ湅鍑洪櫌 4
+            count = patArchiveMapper.countPatArchiveInfoByPhysicalQC(patArchiveReq);
+        } else if (patArchiveReq.getAllhosp() != null && patArchiveReq.getAllhosp() == 4) {
+            //  鏌ョ湅浣忛櫌  1  鏌ョ湅闂ㄨ瘖  2   鏌ョ湅浣撴  3   鏌ョ湅鍑洪櫌 4
+            patArchiveReq.setCry(1);
+            count = patArchiveMapper.countPatArchiveInfoByInhospQC(patArchiveReq);
+        }
+
+        return count;
+    }
 }
 

--
Gitblit v1.9.3