From d1708b4b2bc6596f9c62354274f1af97be45401c Mon Sep 17 00:00:00 2001
From: eight <641137800@qq.com>
Date: 星期四, 28 十一月 2024 14:40:46 +0800
Subject: [PATCH] 按工位的多个检查项目 抢占 排队中 患者

---
 jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/service/queue/QueueServiceImpl.java        |   10 ++++-
 jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/dal/mysql/queue/QueueMapper.java           |   16 ++++++++
 jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/service/queue/QueueServiceTxFunctions.java |   37 +++++++++++++++++-
 3 files changed, 59 insertions(+), 4 deletions(-)

diff --git a/jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/dal/mysql/queue/QueueMapper.java b/jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/dal/mysql/queue/QueueMapper.java
index a344533..b29be78 100644
--- a/jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/dal/mysql/queue/QueueMapper.java
+++ b/jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/dal/mysql/queue/QueueMapper.java
@@ -244,6 +244,22 @@
                                   @Param("seqNum")Integer seqNum, @Param("curStatus")Integer curStatus, @Param("newStatus")Integer newStatus,
                                   @Param("checkType")Integer checkType);
 
+    // 鏁翠釜绯荤粺鑼冨洿鍐� [鎺掗槦涓璢浜哄憳 [琚伐浣嶅尰鐢焆鎶㈠崰 鏍规嵁 澶氫釜妫�鏌ラ」鐩�
+    @Update("<script>" +
+            "update lihu.queue set status = #{newStatus}, room_id = #{roomId}, room_name = #{roomName}, \n" +
+            " bed_no = #{bedNo}, seq_num = #{seqNum} where id = \n" +
+            "  (select a.id from \n" +
+            "    (select id from lihu.queue where status = #{curStatus} " +
+            "       and book_check_type in ( " +
+            "           <foreach collection='checkTypeArray' separator=',' item='_checkType'>" +
+            "             #{_checkType} " +
+            "           </foreach> )" +
+            "       order by jump_flag desc, book_timeslot, create_time limit 1) a) " +
+            "</script>")
+    Integer preemptWaitingPatientWithBedCheckTypes(@Param("roomId")Long roomId, @Param("roomName")String roomName, @Param("bedNo")String bedNo,
+                                  @Param("seqNum")Integer seqNum, @Param("curStatus")Integer curStatus, @Param("newStatus")Integer newStatus,
+                                  @Param("checkTypeArray")Integer[] checkTypeArray);
+
     @Update("update lihu.queue set status = #{newStatus}, seq_num = #{seqNum} " +
             " where id = " +
             "  (select a.id from \n" +
diff --git a/jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/service/queue/QueueServiceImpl.java b/jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/service/queue/QueueServiceImpl.java
index 96a4c0f..cb90a2d 100644
--- a/jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/service/queue/QueueServiceImpl.java
+++ b/jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/service/queue/QueueServiceImpl.java
@@ -336,7 +336,7 @@
         devRent.setCheckType( queueSaveReqVO.getBookCheckType() );
         devRentMapper.insert(devRent);
 
-        startHurryUpOneCheckType( queue.getBookCheckType() );
+        //startHurryUpOneCheckType( queue.getBookCheckType() );
     }
 
     @Override
@@ -545,12 +545,18 @@
         return updateNum;
     }
 
+    /**
+     * 鍔犳��
+     * @param patId
+     * @param jumped
+     * @return
+     */
     @Override
     public Integer patientJump(String patId, Byte jumped) {
         Integer updateNum = queueMapper.queueJump(patId, QueueStatusEnum.WAITING.getStatus(), jumped);
 
         QueueDO queueDO = queueMapper.getQueueByPatId(patId);
-        startHurryUpOneCheckType(Integer.valueOf(queueDO.getBookCheckType()));
+        //startHurryUpOneCheckType(Integer.valueOf(queueDO.getBookCheckType()));
         return updateNum;
     }
 
diff --git a/jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/service/queue/QueueServiceTxFunctions.java b/jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/service/queue/QueueServiceTxFunctions.java
index 5fcef0c..5ac7155 100644
--- a/jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/service/queue/QueueServiceTxFunctions.java
+++ b/jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/service/queue/QueueServiceTxFunctions.java
@@ -418,8 +418,41 @@
         }
 
         // 澶勭悊 鎺掗槦涓� 鎮h��
-        Integer[] checkTypes = bedQueueBO.getCheckTypes();
-        Arrays.stream(checkTypes).forEach(checkType -> hurryupOneCheckType(checkType));
+        hurryupOneBedCheckTypes( bedQueueBO );
+    }
+
+    public void hurryupOneBedCheckTypes(BedQueueBO bedQueueBO) {
+        while (bedQueueBO.queueNum.get() < bedQueueBO.maxQueueNum) {
+            // 鎶㈠崰 鏄惁鏈夋帓闃熶腑鐨勬偅鑰�
+            Integer updateNum = queueMapper.preemptWaitingPatientWithBedCheckTypes(
+                    bedQueueBO.getRoomId(),
+                    bedQueueBO.getRoomName(),
+                    bedQueueBO.getBedNo(),
+                    curSeqNum.get() + 1,
+                    QueueStatusEnum.WAITING.getStatus(),
+                    QueueStatusEnum.READY.getStatus(),
+                    bedQueueBO.checkTypes);
+
+            // 娌℃湁鎶㈠埌鎺掗槦鎮h��
+            if (null == updateNum || 0 == updateNum) {
+                return;
+            }
+
+            QueueDO preemptQueueItem = queueMapper.getQueueItemBySeqNum(curSeqNum.get() + 1);
+            CheckTypeDO checkTypeDO = getCheckTypeItem( preemptQueueItem.getBookCheckType() );
+
+            // 鎶㈠埌鎺掗槦鎮h�呭悗锛屽鐞� 妫�鏌ラ」鐩�.浜插拰鎬� 閫昏緫
+            if ( checkTypeDO.getAffinityCheckTypes().length > 0) {
+                procAffinityWhenPreempt(preemptQueueItem, checkTypeDO.getAffinityCheckTypes());
+            }
+
+            curSeqNum.getAndIncrement();
+
+            bedQueueBO.queueNum.incrementAndGet();
+        }
+
+        // 鏀瑰彉浜嗕紭鍏堥槦鍒楅『搴�
+        refreshPriorityQueue(bedQueueBO);
     }
 
     public void hurryupOneCheckType(Integer checkType) {

--
Gitblit v1.9.3