From 8aebf6bafb60a882ebd84bf727e39ef27233ac32 Mon Sep 17 00:00:00 2001 From: eight <641137800@qq.com> Date: 星期一, 31 三月 2025 14:49:39 +0800 Subject: [PATCH] just refactor --- jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/service/queue/QueueServiceTxFunctions.java | 70 +++++++++++++++++----------------- 1 files changed, 35 insertions(+), 35 deletions(-) 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 22c12cd..10399ac 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,41 +418,7 @@ } // 澶勭悊 鎺掗槦涓� 鎮h�� - 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); + hurryupOneBedCheckTypeList( bedQueueBO ); } /** @@ -547,6 +513,40 @@ log.info(" opening " + openingFlag.get() + " " + monitorInfoVO.getQueueNum() + " " + monitorInfoVO.getActiveQueueNum() + " " + monitorInfoVO.getCheckTypeBedInfo().toString() ); } + private void hurryupOneBedCheckTypeList(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); + } + private void procAffinityWhenPreempt(QueueDO preemptQueueItem, Integer[] affinityCheckTypes) { List<QueueDO> affinityItems = queueMapper.getCurPatGivenCheckTypesAndStatus( preemptQueueItem.getPatId(), affinityCheckTypes, QueueStatusEnum.WAITING.getStatus()); -- Gitblit v1.9.3