From c5f7cf883c94d92cf7ef575b1f73df1f810da7b6 Mon Sep 17 00:00:00 2001
From: 陈昶聿 <chychen@nbjetron.com>
Date: 星期二, 16 十二月 2025 10:59:50 +0800
Subject: [PATCH] 【丽水】writeInSubTask 增加回滚事务

---
 smartor/src/main/java/com/smartor/service/impl/PatMedInhospServiceImpl.java |  219 ++++++++++++++++++++++++++++--------------------------
 1 files changed, 112 insertions(+), 107 deletions(-)

diff --git a/smartor/src/main/java/com/smartor/service/impl/PatMedInhospServiceImpl.java b/smartor/src/main/java/com/smartor/service/impl/PatMedInhospServiceImpl.java
index daade56..b0d1cef 100644
--- a/smartor/src/main/java/com/smartor/service/impl/PatMedInhospServiceImpl.java
+++ b/smartor/src/main/java/com/smartor/service/impl/PatMedInhospServiceImpl.java
@@ -17,6 +17,7 @@
 import org.springframework.beans.factory.annotation.Value;
 import org.springframework.stereotype.Service;
 
+import java.io.IOException;
 import java.time.Instant;
 import java.time.temporal.ChronoUnit;
 import java.util.*;
@@ -579,89 +580,106 @@
             serviceSubtask.setVisitDeptCode(patMedInhosp1.getLeavehospitaldistrictcode());
             serviceSubtask.setVisitDeptName(patMedInhosp1.getLeavehospitaldistrictname());
         }
-
-
         Integer i = 0;
-        //鍏堝垽鏂竴涓嬶紝鏄惁闇�瑕佹牎楠�
-        if (check && (Objects.isNull(serviceSubtask.getTaskSituation()) || serviceSubtask.getTaskSituation() != 6)) {
-            //鍦ㄦ柊澧炰箣鍓嶏紝鍏堥�氳繃鎮h�匢D锛宻endstate=2鏌ヨ涓�涓嬶紝鍦ㄦ墍鏈夐暱鏈熶换鍔′腑锛屾槸涓嶆槸杩樻湁璇ユ偅鑰呭緟鎵ц鐨勪换鍔★紝鏈夌殑璇�,姣旇緝涔嬪墠鐨別ndtime鏄惁灏忎簬褰撳墠鐨別ndtaime,濡傛灉涔嬪墠鐨勫皬浜庣幇鍦ㄧ殑锛屽垯鐩存帴灏嗕箣鍓嶇殑鍋滄帀锛堝師鍥犲啀鍏ラ櫌锛�
-            ServiceSubtaskVO subtask = new ServiceSubtaskVO();
-            subtask.setPatid(patArchive.getId());
-            subtask.setSendstate(2L);
-            subtask.setTaskid(taskid);
-            List<ServiceSubtask> selectServiceSubtaskList = serviceSubtaskMapper.selectServiceSubtaskList(subtask);
-            log.info("璇ユ偅鑰呭緟鎵ц鐨勪换鍔�:{}", CollectionUtils.isNotEmpty(selectServiceSubtaskList) ? selectServiceSubtaskList.size() : null);
-            if (CollectionUtils.isNotEmpty(selectServiceSubtaskList) && selectServiceSubtaskList.size() > 0) {
-                for (ServiceSubtask serviceSubtask1 : selectServiceSubtaskList) {
-                    if (Objects.isNull(serviceSubtask1.getLongSendTime())) {
-                        //涓嶆槸闀挎湡浠诲姟锛屼笉澶勭悊
-                        continue;
-                    }
-                    //type = 1鎴�2 琛ㄧず 鈥濈瀹ゃ�佺梾鍖衡��
-                    if (type == 1 || type == 2) {
-                        Date endTime = serviceSubtask.getEndtime();
-                        Date endTime1 = serviceSubtask1.getEndtime();
-                        //鍑洪櫌鏃堕棿鍒ょ┖锛屽鏋滀负绌鸿烦杩�
-                        if(Objects.isNull(endTime)){
-                            serviceSubtask.setResult("error");
-                            serviceSubtask.setRemark("鍑洪櫌鏃堕棿涓虹┖锛宻erviceSubtask鐨処d涓�" + serviceSubtask.getId());
-                            serviceSubtask.setUpdateBy(serviceTask.getUpdateBy());
-                            serviceSubtask.setUpdateTime(new Date());
-                            Boolean aBoolean = serviceSubtaskMapper.updateServiceSubtask(serviceSubtask1);
-                            if (aBoolean) i = 1;
+        try {
+            //鍏堝垽鏂竴涓嬶紝鏄惁闇�瑕佹牎楠�
+            if (check && (Objects.isNull(serviceSubtask.getTaskSituation()) || serviceSubtask.getTaskSituation() != 6)) {
+                //鍦ㄦ柊澧炰箣鍓嶏紝鍏堥�氳繃鎮h�匢D锛宻endstate=2鏌ヨ涓�涓嬶紝鍦ㄦ墍鏈夐暱鏈熶换鍔′腑锛屾槸涓嶆槸杩樻湁璇ユ偅鑰呭緟鎵ц鐨勪换鍔★紝鏈夌殑璇�,姣旇緝涔嬪墠鐨別ndtime鏄惁灏忎簬褰撳墠鐨別ndtaime,濡傛灉涔嬪墠鐨勫皬浜庣幇鍦ㄧ殑锛屽垯鐩存帴灏嗕箣鍓嶇殑鍋滄帀锛堝師鍥犲啀鍏ラ櫌锛�
+                ServiceSubtaskVO subtask = new ServiceSubtaskVO();
+                subtask.setPatid(patArchive.getId());
+                subtask.setSendstate(2L);
+                subtask.setTaskid(taskid);
+                List<ServiceSubtask> selectServiceSubtaskList = serviceSubtaskMapper.selectServiceSubtaskList(subtask);
+                log.info("璇ユ偅鑰呭緟鎵ц鐨勪换鍔�:{}", CollectionUtils.isNotEmpty(selectServiceSubtaskList) ? selectServiceSubtaskList.size() : null);
+                if (CollectionUtils.isNotEmpty(selectServiceSubtaskList) && selectServiceSubtaskList.size() > 0) {
+                    for (ServiceSubtask serviceSubtask1 : selectServiceSubtaskList) {
+                        if (Objects.isNull(serviceSubtask1.getLongSendTime())) {
+                            //涓嶆槸闀挎湡浠诲姟锛屼笉澶勭悊
                             continue;
                         }
-                        if(Objects.isNull(endTime1)){
-                            serviceSubtask1.setResult("error");
-                            serviceSubtask1.setRemark("鍑洪櫌鏃堕棿涓虹┖锛宻erviceSubtask鐨処d涓�" + serviceSubtask1.getId());
-                            serviceSubtask1.setUpdateBy(serviceTask.getUpdateBy());
-                            serviceSubtask1.setUpdateTime(new Date());
-                            Boolean aBoolean = serviceSubtaskMapper.updateServiceSubtask(serviceSubtask1);
-                            if (aBoolean) i = 1;
-                            continue;
-                        }
-                        if (endTime1.before(endTime) && serviceSubtask1.getServiceType().equals("2")) {
-                            //濡傛灉褰撳墠寰幆鐨勫瓙浠诲姟鐨勫嚭闄㈡椂闂村湪鈥滃噯澶囨柊澧炵殑瀛愪换鍔♀�濈殑鍑洪櫌鏃堕棿涔嬪墠锛屽垯灏嗗惊鐜殑瀛愪换鍔″仠鎺�
+                        //type = 1鎴�2 琛ㄧず 鈥濈瀹ゃ�佺梾鍖衡��
+                        if (type == 1 || type == 2) {
+                            Date endTime = serviceSubtask.getEndtime();
+                            Date endTime1 = serviceSubtask1.getEndtime();
+                            //鍑洪櫌鏃堕棿鍒ょ┖锛屽鏋滀负绌鸿烦杩�
+                            if(Objects.isNull(endTime)){
+                                serviceSubtask.setResult("error");
+                                serviceSubtask.setRemark("鍑洪櫌鏃堕棿涓虹┖锛宻erviceSubtask鐨処d涓�" + serviceSubtask.getId());
+                                serviceSubtask.setUpdateBy(serviceTask.getUpdateBy());
+                                serviceSubtask.setUpdateTime(new Date());
+                                Boolean aBoolean = serviceSubtaskMapper.updateServiceSubtask(serviceSubtask1);
+                                if (aBoolean) i = 1;
+                                continue;
+                            }
+                            if(Objects.isNull(endTime1)){
+                                serviceSubtask1.setResult("error");
+                                serviceSubtask1.setRemark("鍑洪櫌鏃堕棿涓虹┖锛宻erviceSubtask鐨処d涓�" + serviceSubtask1.getId());
+                                serviceSubtask1.setUpdateBy(serviceTask.getUpdateBy());
+                                serviceSubtask1.setUpdateTime(new Date());
+                                Boolean aBoolean = serviceSubtaskMapper.updateServiceSubtask(serviceSubtask1);
+                                if (aBoolean) i = 1;
+                                continue;
+                            }
+                            if (endTime1.before(endTime) && serviceSubtask1.getServiceType().equals("2")) {
+                                //濡傛灉褰撳墠寰幆鐨勫瓙浠诲姟鐨勫嚭闄㈡椂闂村湪鈥滃噯澶囨柊澧炵殑瀛愪换鍔♀�濈殑鍑洪櫌鏃堕棿涔嬪墠锛屽垯灏嗗惊鐜殑瀛愪换鍔″仠鎺�
+                                serviceSubtask1.setSendstate(4L);
+                                if (StringUtils.isNotEmpty(serviceSubtask.getRemark()))
+                                    serviceSubtask.setRemark(serviceSubtask.getRemark() + ",鐤剧梾鎮h�呭啀鍏ラ櫌");
+                                else serviceSubtask.setRemark("鐤剧梾鎮h�呭啀鍏ラ櫌");
+                                serviceSubtask1.setResult("error");
+//                            serviceSubtask1.setFinishtime(new Date());
+                                serviceSubtask1.setUpdateBy(serviceTask.getUpdateBy());
+                                serviceSubtask1.setUpdateTime(new Date());
+                                Boolean aBoolean = serviceSubtaskMapper.updateServiceSubtask(serviceSubtask1);
+                                if (aBoolean) i = 1;
+                            } else {
+                                //鐩稿弽,鍒欏皢褰撴湁鐨勬暟鎹仠鎺�
+                                serviceSubtask.setResult("error");
+//                            serviceSubtask.setFinishtime(new Date());
+                                serviceSubtask.setSendstate(4L);
+                                if (StringUtils.isNotEmpty(serviceSubtask.getRemark()))
+                                    serviceSubtask.setRemark(serviceSubtask.getRemark() + ",褰撳墠鎮h�呭嚭闄㈡椂闂村悗鏈夊緟鎵ц鐨勫嚭闄㈤殢璁块暱鏈熶换鍔�");
+                                else serviceSubtask.setRemark("褰撳墠鎮h�呭嚭闄㈡椂闂村悗鏈夊緟鎵ц鐨勫嚭闄㈤殢璁块暱鏈熶换鍔�");
+                                serviceSubtask.setCreateBy(serviceTask.getCreateBy());
+                                serviceSubtask.setCreateTime(new Date());
+                                i = serviceSubtaskMapper.insertServiceSubtask(serviceSubtask);
+                            }
+                        } else if (type == 3) {
+                            //type=3 琛ㄧず鐤剧梾
+                            //灏嗕箣鍓嶇殑鍋滄帀
                             serviceSubtask1.setSendstate(4L);
                             if (StringUtils.isNotEmpty(serviceSubtask.getRemark()))
                                 serviceSubtask.setRemark(serviceSubtask.getRemark() + ",鐤剧梾鎮h�呭啀鍏ラ櫌");
                             else serviceSubtask.setRemark("鐤剧梾鎮h�呭啀鍏ラ櫌");
                             serviceSubtask1.setResult("error");
-//                            serviceSubtask1.setFinishtime(new Date());
-                            serviceSubtask1.setUpdateBy(serviceTask.getUpdateBy());
-                            serviceSubtask1.setUpdateTime(new Date());
-                            Boolean aBoolean = serviceSubtaskMapper.updateServiceSubtask(serviceSubtask1);
-                            if (aBoolean) i = 1;
-                        } else {
-                            //鐩稿弽,鍒欏皢褰撴湁鐨勬暟鎹仠鎺�
-                            serviceSubtask.setResult("error");
-//                            serviceSubtask.setFinishtime(new Date());
-                            serviceSubtask.setSendstate(4L);
-                            if (StringUtils.isNotEmpty(serviceSubtask.getRemark()))
-                                serviceSubtask.setRemark(serviceSubtask.getRemark() + ",褰撳墠鎮h�呭嚭闄㈡椂闂村悗鏈夊緟鎵ц鐨勫嚭闄㈤殢璁块暱鏈熶换鍔�");
-                            else serviceSubtask.setRemark("褰撳墠鎮h�呭嚭闄㈡椂闂村悗鏈夊緟鎵ц鐨勫嚭闄㈤殢璁块暱鏈熶换鍔�");
-                            serviceSubtask.setCreateBy(serviceTask.getCreateBy());
-                            serviceSubtask.setCreateTime(new Date());
-                            i = serviceSubtaskMapper.insertServiceSubtask(serviceSubtask);
-                        }
-                    } else if (type == 3) {
-                        //type=3 琛ㄧず鐤剧梾
-                        //灏嗕箣鍓嶇殑鍋滄帀
-                        serviceSubtask1.setSendstate(4L);
-                        if (StringUtils.isNotEmpty(serviceSubtask.getRemark()))
-                            serviceSubtask.setRemark(serviceSubtask.getRemark() + ",鐤剧梾鎮h�呭啀鍏ラ櫌");
-                        else serviceSubtask.setRemark("鐤剧梾鎮h�呭啀鍏ラ櫌");
-                        serviceSubtask1.setResult("error");
 //                        serviceSubtask1.setFinishtime(new Date());
-                        serviceSubtask1.setUpdateBy(serviceTask.getUpdateBy());
-                        serviceSubtaskMapper.updateServiceSubtask(serviceSubtask1);
-                        //閲嶆柊鏂板瀛愪换鍔�
-                        i = serviceSubtaskMapper.insertServiceSubtask(serviceSubtask);
-                        //杩欓噷闇�瑕佸叏澶辫触
-                        addServiceSubtaskPreachform(serviceSubtask, "5");
+                            serviceSubtask1.setUpdateBy(serviceTask.getUpdateBy());
+                            serviceSubtaskMapper.updateServiceSubtask(serviceSubtask1);
+                            //閲嶆柊鏂板瀛愪换鍔�
+                            i = serviceSubtaskMapper.insertServiceSubtask(serviceSubtask);
+                            //杩欓噷闇�瑕佸叏澶辫触
+                            addServiceSubtaskPreachform(serviceSubtask, "5");
 
+                        }
                     }
+                } else {
+                    if (StringUtils.isEmpty(serviceSubtask.getPhone())) {
+                        if (StringUtils.isNotEmpty(serviceSubtask.getRemark()))
+                            serviceSubtask.setRemark(serviceSubtask.getRemark() + ",鎵嬫満鍙蜂负绌�");
+                        else serviceSubtask.setRemark("鎵嬫満鍙蜂负绌�");
+                        serviceSubtask.setSendstate(4L);
+                        serviceSubtask.setResult("error");
+                    }
+                    serviceSubtask.setCreateBy(serviceTask.getCreateBy());
+                    serviceSubtask.setCreateTime(new Date());
+                    i = serviceSubtaskMapper.insertServiceSubtask(serviceSubtask);
+                    addServiceSubtaskPreachform(serviceSubtask, null);
                 }
+            } else if (serviceSubtask.getTaskSituation() == 6) {
+                //璇存槑璇ユ偅鑰呮槸琚繃婊ょ殑锛屼笉鐢ㄥ啀鎵ц浜�
+                serviceSubtask.setCreateBy(serviceTask.getCreateBy());
+                serviceSubtask.setCreateTime(new Date());
+                i = serviceSubtaskMapper.insertServiceSubtask(serviceSubtask);
             } else {
                 if (StringUtils.isEmpty(serviceSubtask.getPhone())) {
                     if (StringUtils.isNotEmpty(serviceSubtask.getRemark()))
@@ -675,43 +693,30 @@
                 i = serviceSubtaskMapper.insertServiceSubtask(serviceSubtask);
                 addServiceSubtaskPreachform(serviceSubtask, null);
             }
-        } else if (serviceSubtask.getTaskSituation() == 6) {
-            //璇存槑璇ユ偅鑰呮槸琚繃婊ょ殑锛屼笉鐢ㄥ啀鎵ц浜�
-            serviceSubtask.setCreateBy(serviceTask.getCreateBy());
-            serviceSubtask.setCreateTime(new Date());
-            i = serviceSubtaskMapper.insertServiceSubtask(serviceSubtask);
-        } else {
-            if (StringUtils.isEmpty(serviceSubtask.getPhone())) {
-                if (StringUtils.isNotEmpty(serviceSubtask.getRemark()))
-                    serviceSubtask.setRemark(serviceSubtask.getRemark() + ",鎵嬫満鍙蜂负绌�");
-                else serviceSubtask.setRemark("鎵嬫満鍙蜂负绌�");
-                serviceSubtask.setSendstate(4L);
-                serviceSubtask.setResult("error");
-            }
-            serviceSubtask.setCreateBy(serviceTask.getCreateBy());
-            serviceSubtask.setCreateTime(new Date());
-            i = serviceSubtaskMapper.insertServiceSubtask(serviceSubtask);
-            addServiceSubtaskPreachform(serviceSubtask, null);
-        }
-        if (i == 1) {
-            //灏哻heck_flag鏀规垚1锛堝凡澶勭悊锛�
-            PatMedInhosp patMedInhosp2 = new PatMedInhosp();
-            patMedInhosp2.setInhospid(patMedInhosp1.getInhospid());
-            if (type == 1) patMedInhosp2.setDeptcheckFlag("1");
-            if (type == 2) patMedInhosp2.setWardcheckFlag("1");
-            if (type == 3) patMedInhosp2.setDiagcheckFlag("1");
 
-            patMedInhospMapper.updatePatMedInhosp(patMedInhosp2);
-        } else {
-            //鐢熸垚瀛愪换鍔″け璐ワ紝
-            log.info("鐢熸垚瀛愪换鍔″け璐erviceSubtask鐨則askid涓猴細{},patid涓猴細{}", serviceSubtask.getTaskid(), serviceSubtask.getPatid());
-            PatMedInhosp patMedInhosp2 = new PatMedInhosp();
-            patMedInhosp2.setInhospid(patMedInhosp1.getInhospid());
-            if (type == 1) patMedInhosp2.setDeptcheckFlag("2");
-            if (type == 2) patMedInhosp2.setWardcheckFlag("2");
-            if (type == 3) patMedInhosp2.setDiagcheckFlag("2");
-            patMedInhosp2.setRemark("鐢熸垚瀛愪换鍔″け璐� " + type);
-            patMedInhospMapper.updatePatMedInhosp(patMedInhosp2);
+            //灏哻heck_flag鏀规垚1锛堝凡澶勭悊锛�
+            if(i == 1){
+                PatMedInhosp patMedInhosp2 = new PatMedInhosp();
+                patMedInhosp2.setInhospid(patMedInhosp1.getInhospid());
+                if (type == 1) patMedInhosp2.setDeptcheckFlag("1");
+                if (type == 2) patMedInhosp2.setWardcheckFlag("1");
+                if (type == 3) patMedInhosp2.setDiagcheckFlag("1");
+                patMedInhospMapper.updatePatMedInhosp(patMedInhosp2);
+            }else {
+                //鐢熸垚瀛愪换鍔″け璐ワ紝
+                log.info("鐢熸垚瀛愪换鍔″け璐erviceSubtask鐨則askid涓猴細{},patid涓猴細{}", serviceSubtask.getTaskid(), serviceSubtask.getPatid());
+                PatMedInhosp patMedInhosp2 = new PatMedInhosp();
+                patMedInhosp2.setInhospid(patMedInhosp1.getInhospid());
+                if (type == 1) patMedInhosp2.setDeptcheckFlag("2");
+                if (type == 2) patMedInhosp2.setWardcheckFlag("2");
+                if (type == 3) patMedInhosp2.setDiagcheckFlag("2");
+                patMedInhosp2.setRemark("鐢熸垚瀛愪换鍔″け璐� " + type);
+                patMedInhospMapper.updatePatMedInhosp(patMedInhosp2);
+            }
+        } catch (Exception e) {
+            //鍑洪敊鍥炴粴浜嬪姟
+            log.info("鐢熸垚瀛愪换鍔℃姤閿欏洖婊歴erviceSubtask鐨則askid涓猴細{},patid涓猴細{}", serviceSubtask.getTaskid(), serviceSubtask.getPatid());
+            e.printStackTrace();
         }
     }
 

--
Gitblit v1.9.3