YYC
2023-09-04 ea9420519d4c3f825f53831208cd4b72c2eecea3
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
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
package com.fzzy.async.fzzy40.impl;
 
import com.fzzy.api.Constant;
import com.fzzy.api.entity.Api1101;
import com.fzzy.api.entity.Api1102;
import com.fzzy.api.entity.Api1108;
import com.fzzy.api.entity.ApiLog;
import com.fzzy.api.utils.ContextUtil;
import com.fzzy.api.view.repository.Api1101Rep;
import com.fzzy.api.view.repository.Api1102Rep;
import com.fzzy.api.view.repository.Api1108Rep;
import com.fzzy.api.view.repository.ApiLogRep;
import com.fzzy.async.fzzy40.entity.Fz40Drug;
import com.fzzy.async.fzzy40.repository.Fzzy40Sync1108Rep;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Component;
 
import java.util.Date;
import java.util.List;
 
/**
 * 药剂信息同步
 *
 * @Author:YAN
 */
@Slf4j
@Component
public class Fzzy40Sync1108 {
 
    @Autowired
    private Fzzy40Sync1108Rep fzzy40Sync1108Rep;
    @Autowired
    private ApiLogRep apiLogRep;
    @Autowired
    private Api1101Rep api1101Rep;
    @Autowired
    private Api1102Rep api1102Rep;
    @Autowired
    private Api1108Rep api1108Rep;
 
 
    /**
     * 同步药剂信息
     *
     * @param kqdm
     * @param deptId
     * @param start
     * @param end
     */
    public void syncData(String kqdm, String deptId, Date start, Date end) {
        log.info("-------------1108接口药剂信息开始同步------------------");
 
        //同步数据,只记录失败的信息
        ApiLog apiLog = new ApiLog();
        apiLog.setType(ApiLog.TYPE_SYNC);
        apiLog.setKqdm(deptId);
        apiLog.setUploadTime(new Date());
        apiLog.setInteId(Constant.API_CODE_1108);
        apiLog.setStatus(99);
        apiLog.setId(ContextUtil.getUUID());
 
        try {
            List<Fz40Drug> list = fzzy40Sync1108Rep.listDrug(deptId);
 
            if (null == list || list.isEmpty()) {
                log.info("-------------没有获取到药剂信息------------------");
                return;
            }
            Api1102 api1102 = api1102Rep.findById(kqdm).get();
            Api1101 api1101 = api1101Rep.findById(api1102.getDwdm()).get();
            Api1108 apiData;
            for (Fz40Drug sysData : list) {
 
                apiData = new Api1108();
                apiData.setId(ContextUtil.getUUID());//ID
                apiData.setBizId(sysData.getId());//业务id
                apiData.setDwdm(api1101.getDwdm());//单位代码
                apiData.setKqdm(api1102.getKqdm());//库区代码
                apiData.setKqmc(api1102.getKqmc());//库区名称
                apiData.setYjbh(sysData.getId());//药剂编号
                apiData.setYjmc(sysData.getName());//药剂名称
                apiData.setBzw(sysData.getBzw());//包装物
                apiData.setGgxh(sysData.getGgxh());//型号规格
                apiData.setAqsysms(sysData.getAqsysms());//安全使用说明书
                apiData.setSccj(sysData.getSccj());//生产厂家
                apiData.setCgly(sysData.getCgly());//采购来源
                apiData.setCctj(sysData.getCctj());//存储条件
                apiData.setCcdd(sysData.getCcdd());//储存地点
                apiData.setBzwclfs(sysData.getBzwclfs());//包装物处理方式
                apiData.setCzclfs(sysData.getCzclfs());//残渣处理方式
                apiData.setBzq(sysData.getBzq());//保质期
                apiData.setCgrq(sysData.getCgrq());//采购日期
                apiData.setKcsl(sysData.getCount());//库存数量
                apiData.setKcsldw(sysData.getKcsldw());//库存数量单位
                apiData.setCzbz(Constant.CZBZ_I);//操作标志
                apiData.setZhgxsj(sysData.getUpdateTime());//最后更新时间
 
                //保存数据
                api1108Rep.save(apiData);
                log.info("1108---同步数据:{}", apiData.toString());
            }
 
        } catch (Exception e) {
            log.error("---药剂信息同步执行失败----{}", e.toString());
            apiLog.setResult("药剂信息同步执行失败:" + e.getMessage());
            apiLogRep.save(apiLog);
        }
    }
}