From 4b278300e8b3b1faabd5d080990cd3124f68612c Mon Sep 17 00:00:00 2001 From: eight <641137800@qq.com> Date: 星期二, 26 十一月 2024 13:09:28 +0800 Subject: [PATCH] 会取下一个时段的序号 --- jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/service/queuesequence/QueueSequenceServiceImpl.java | 77 ++++++++++++++++++++++++++++++++++++++ 1 files changed, 77 insertions(+), 0 deletions(-) diff --git a/jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/service/queuesequence/QueueSequenceServiceImpl.java b/jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/service/queuesequence/QueueSequenceServiceImpl.java index d99ebbd..d48bf41 100644 --- a/jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/service/queuesequence/QueueSequenceServiceImpl.java +++ b/jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/service/queuesequence/QueueSequenceServiceImpl.java @@ -48,6 +48,15 @@ private CheckTypeMapper checkTypeMapper; @Override + public void initQueueSequenceTable() { + queueSequenceMapper.clearQueueSequenceTableNotCurrent(); + Integer rowCount = queueSequenceMapper.getQueueSequenceTableRowCount(); + if (null == rowCount || 0 == rowCount) { + resetQueueSequence(); + } + } + + @Override public Integer createQueueSequence(QueueSequenceSaveReqVO createReqVO) { // 鎻掑叆 QueueSequenceDO queueSequence = BeanUtils.toBean(createReqVO, QueueSequenceDO.class); @@ -85,6 +94,11 @@ } @Override + public List<QueueSequenceDO> selectGivenCheckTypeTimeslot(Integer checkType) { + return queueSequenceMapper.selectTimeslotByCheckType( checkType ); + } + + @Override public PageResult<QueueSequenceDO> getQueueSequencePage(QueueSequencePageReqVO pageReqVO) { return queueSequenceMapper.selectPage(pageReqVO); } @@ -119,5 +133,68 @@ }); } + @Override + @Transactional + public Integer distributeSeqNo(Integer checkType, Integer timeslot) { + Integer curSeqNo = queueSequenceMapper.selectQueueNoForUpdate(checkType, timeslot); + if (null == curSeqNo) { + // 浠庝笅涓�涓椂娈� 鑾峰彇搴忓彿銆傚師鍥犵郴缁熺敤30鍒嗛挓鐨勯棿闅斿垝鍒嗛绾︽椂闂存锛孒IS鐨勯绾︽椂闂存鍙兘鏄�30鍒嗛挓鎴�60鍒嗛挓 + Integer nextTimeslot = getNextTimeSlot(timeslot, checkType); + if (null == nextTimeslot) { + throw exception(QUEUE_SEQUENCE_TIMESLOT_FULL); + } + + curSeqNo = queueSequenceMapper.selectQueueNoForUpdate(checkType, nextTimeslot); + if (null == curSeqNo) { + throw exception(QUEUE_SEQUENCE_TIMESLOT_FULL); + } + + Integer updateRowNum = queueSequenceMapper.updateGivenCheckTypeTimeslotSeqNo(checkType, nextTimeslot, curSeqNo); + if (null == updateRowNum || updateRowNum == 0) { + throw exception(QUEUE_SEQUENCE_TIMESLOT_EXCEPTION); + } + + } else { + Integer updateRowNum = queueSequenceMapper.updateGivenCheckTypeTimeslotSeqNo(checkType, timeslot, curSeqNo); + if (null == updateRowNum || updateRowNum == 0) { + throw exception(QUEUE_SEQUENCE_TIMESLOT_EXCEPTION); + } + } + + return curSeqNo + 1; + } + + @Override + @Transactional + public Integer distributeVipSeqNo(Integer checkType, Integer timeslot) { + Integer curVipSeqNo = queueSequenceMapper.selectQueueVipNoForUpdate(checkType, timeslot); + if (null == curVipSeqNo) { + throw exception(QUEUE_SEQUENCE_TIMESLOT_FULL); + } + + Integer updateRowNum = queueSequenceMapper.updateGivenCheckTypeTimeslotVipSeqNo(checkType, timeslot, curVipSeqNo); + if (null == updateRowNum || updateRowNum == 0) { + throw exception(QUEUE_SEQUENCE_TIMESLOT_EXCEPTION); + } + + return curVipSeqNo + 1; + } + + private Integer getNextTimeSlot(Integer timeslot, Integer checkType) { + List<DictDataRespDTO> dictBookTimeslotList = dictDataApi.getDictDataList(ECG_BOOK_TIMESLOT); + Optional<Integer> index = dictBookTimeslotList.stream() + .filter(e -> e.getValue().equals(String.valueOf(timeslot))) + .findFirst() + .map(dictBookTimeslotList::indexOf); + if (!index.isPresent()) + return null; + + if (dictBookTimeslotList.size() <= (index.get() + 1)) + return null; + + DictDataRespDTO dictDataRespDTO = dictBookTimeslotList.get(index.get() + 1); + return Integer.valueOf(dictDataRespDTO.getValue()); + } + } -- Gitblit v1.9.3