liusheng
昨天 b57304d9917beab4671442a0018c1c3a2d681640
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
package com.smartor.statemachine.handler.impl;
 
import com.ruoyi.common.utils.StringUtils;
import com.smartor.domain.PatMedInhosp;
import com.smartor.service.IPatMedInhospService;
import com.smartor.statemachine.handler.InhospStateHandler;
import lombok.extern.slf4j.Slf4j;
import org.apache.commons.collections4.CollectionUtils;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Component;
 
import java.util.List;
 
/**
 * 入院状态处理器
 * 
 * @author smartor
 */
@Slf4j
@Component
public class InHospitalHandler implements InhospStateHandler {
 
    @Autowired
    private IPatMedInhospService patMedInhospService;
 
    @Override
    public boolean handle(PatMedInhosp patMedInhosp) {
        log.info("【InHospitalHandler】处理入院逻辑,serialnum={}, orgid={}", 
                patMedInhosp.getSerialnum(), patMedInhosp.getOrgid());
 
        PatMedInhosp query = new PatMedInhosp();
        query.setPatno(StringUtils.trim(patMedInhosp.getPatno()));
        query.setSerialnum(StringUtils.trim(patMedInhosp.getSerialnum()));
        query.setOrgid(StringUtils.trim(patMedInhosp.getOrgid()));
 
        // 1. 先检查是否已存在入院记录
        query.setInhospstate("0");
        List<PatMedInhosp> inHospitalRecords = patMedInhospService.selectPatMedInhosp(query);
        if (CollectionUtils.isNotEmpty(inHospitalRecords)) {
            log.warn("【InHospitalHandler】入院记录已存在,跳过,serialnum={}, orgid={}", 
                    patMedInhosp.getSerialnum(), patMedInhosp.getOrgid());
            return false;
        }
 
        // 2. 检查是否存在预入院记录
        query.setInhospstate("3");
        List<PatMedInhosp> preAdmissionRecords = patMedInhospService.selectPatMedInhosp(query);
        if (CollectionUtils.isNotEmpty(preAdmissionRecords)) {
            // 存在预入院记录,执行状态更新
            try {
                patMedInhosp.setInhospstate("0");
                patMedInhosp.setInhospid(preAdmissionRecords.get(0).getInhospid());
                int updateCount = patMedInhospService.updatePatMedInhosp(patMedInhosp);
                log.info("【InHospitalHandler】更新预入院记录为入院状态,serialnum={}, updateCount={}", 
                        patMedInhosp.getSerialnum(), updateCount);
                return updateCount > 0;
            } catch (Exception e) {
                log.error("【InHospitalHandler】更新预入院记录失败:serialnum={}, orgid={}, 错误:{}", 
                        patMedInhosp.getSerialnum(), patMedInhosp.getOrgid(), e.getMessage(), e);
                return false;
            }
        }
 
        // 3. 检查是否已出院(如果已出院则不允许直接入院)
        query.setInhospstate("1");
        List<PatMedInhosp> dischargedRecords = patMedInhospService.selectPatMedInhosp(query);
        if (CollectionUtils.isNotEmpty(dischargedRecords)) {
            log.warn("【InHospitalHandler】患者已出院,不允许再次入院,serialnum={}, orgid={}", 
                    patMedInhosp.getSerialnum(), patMedInhosp.getOrgid());
            return false;
        }
 
        // 4. 不存在任何记录,直接插入入院记录
        try {
            patMedInhosp.setInhospstate("0");
            patMedInhospService.insertPatMedInhosp(patMedInhosp);
            log.info("【InHospitalHandler】成功插入入院记录,serialnum={}", patMedInhosp.getSerialnum());
            return true;
        } catch (org.springframework.dao.DuplicateKeyException e) {
            log.warn("【InHospitalHandler】入院记录已存在(并发插入),跳过:serialnum={}, orgid={}", 
                    patMedInhosp.getSerialnum(), patMedInhosp.getOrgid());
            return false;
        } catch (Exception e) {
            log.error("【InHospitalHandler】插入入院记录失败:serialnum={}, orgid={}, 错误:{}", 
                    patMedInhosp.getSerialnum(), patMedInhosp.getOrgid(), e.getMessage(), e);
            return false;
        }
    }
 
    @Override
    public String getStateCode() {
        return "0";
    }
}