StrDeathDiscussionFacade.java 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230
  1. package com.lantone.data.facade.dataStr;
  2. import com.alibaba.fastjson.JSON;
  3. import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
  4. import com.baomidou.mybatisplus.generator.config.rules.NamingStrategy;
  5. import com.diagbot.dto.RespDTO;
  6. import com.diagbot.dto.data.ColumnZhAndChDTO;
  7. import com.diagbot.entity.StrDeathDiscussion;
  8. import com.diagbot.enums.CacheKeyEnum;
  9. import com.diagbot.enums.IsDeleteEnum;
  10. import com.diagbot.facade.data.AMedAbnormalInfoFacade;
  11. import com.diagbot.facade.data.ColumnFacade;
  12. import com.diagbot.service.impl.StrDeathDiscussionServiceImpl;
  13. import com.diagbot.util.DateUtil;
  14. import com.diagbot.util.EntityUtil;
  15. import com.diagbot.util.MapUtil;
  16. import com.diagbot.util.StringUtil;
  17. import com.diagbot.vo.data.AStrDeathDiscussionVO;
  18. import com.diagbot.vo.str.StrContentVO;
  19. import com.diagbot.vo.str.StrDeathDiscussionVO;
  20. import com.google.common.collect.Lists;
  21. import org.springframework.beans.BeanUtils;
  22. import org.springframework.beans.factory.annotation.Autowired;
  23. import org.springframework.beans.factory.annotation.Qualifier;
  24. import org.springframework.beans.factory.annotation.Value;
  25. import org.springframework.stereotype.Component;
  26. import java.util.Date;
  27. import java.util.List;
  28. import java.util.Map;
  29. @Component
  30. public class StrDeathDiscussionFacade extends StrDeathDiscussionServiceImpl {
  31. @Autowired
  32. @Qualifier("strDeathDiscussionServiceImpl")
  33. private StrDeathDiscussionServiceImpl strDeathDiscussionService;
  34. @Autowired
  35. private ColumnFacade columnFacade;
  36. @Autowired
  37. private AMedAbnormalInfoFacade aMedAbnormalInfoFacade;
  38. @Value("${log_switch.enable}")
  39. private boolean logSwitch;
  40. public void getColumnZhAndCh(){
  41. List<ColumnZhAndChDTO> list=this.baseMapper.getColumnZhAndCh();
  42. list.forEach(s->{
  43. s.setEn(NamingStrategy.underlineToCamel(s.getEn()));
  44. });
  45. Map<String, String> columnMap= EntityUtil.makeMapWithKeyValue(list,"ch","en");
  46. Boolean flag=columnFacade.createColumn(columnMap,"strDeathDiscussion");
  47. //Map<String, String> map=columnFacade.getColumn("strConsultationNote");
  48. if(!flag){
  49. return;
  50. }
  51. }
  52. /**
  53. * @Description:不解析时入库
  54. * @Author:liuqq
  55. * @time: ${DATE} ${TIME}
  56. **/
  57. public void dealData(StrContentVO strContentVO){
  58. StrDeathDiscussion strDeathDiscussion=new StrDeathDiscussion();
  59. strDeathDiscussion.setRecId(strContentVO.getRecId());
  60. strDeathDiscussion.setBehospitalCode(strContentVO.getBehospitalCode());
  61. strDeathDiscussion.setHospitalId(strContentVO.getHospitalId());
  62. strDeathDiscussion.setWholeData(strContentVO.getWholeData());
  63. //判断数据库中是否存在,不存在insert
  64. if (isExist(strDeathDiscussion)) {
  65. strDeathDiscussion.setGmtCreate(new Date());//记录创建时间
  66. this.save(strDeathDiscussion);
  67. } else {
  68. strDeathDiscussion.setGmtModified(new Date());//记录修改时间
  69. this.update(strDeathDiscussion, new QueryWrapper<StrDeathDiscussion>()
  70. .eq("rec_id", strDeathDiscussion.getRecId())
  71. .eq("hospital_id", strDeathDiscussion.getHospitalId())
  72. .eq("behospital_code", strDeathDiscussion.getBehospitalCode()));
  73. }
  74. }
  75. /**
  76. * @Description:解析后存储数据
  77. * @Author:liuqq
  78. * @time: ${DATE} ${TIME}
  79. **/
  80. public void dealData(String columnMap,Map<String, Object> entityMap,Long hospitalId){
  81. StrDeathDiscussion strDeathDiscussion=new StrDeathDiscussion();
  82. try {
  83. AStrDeathDiscussionVO strDeathDiscussionVO=(AStrDeathDiscussionVO) MapUtil.mapToObject(entityMap, AStrDeathDiscussionVO.class);
  84. BeanUtils.copyProperties(strDeathDiscussionVO,strDeathDiscussion);
  85. strDeathDiscussion.setHospitalId(hospitalId);//医院编码
  86. strDeathDiscussion.setAuditDate(DateUtil.parseDateTime(strDeathDiscussionVO.getAuditDate()));//审核时间
  87. strDeathDiscussion.setRecDate(DateUtil.parseDateTime(strDeathDiscussionVO.getRecDate()));//记录时间
  88. strDeathDiscussion.setDeathDate(DateUtil.parseDateTime(strDeathDiscussionVO.getDeathDate()));//死亡时间
  89. strDeathDiscussion.setDiscussDate(DateUtil.parseDate(strDeathDiscussionVO.getDiscussDate()));//讨论时间
  90. strDeathDiscussion.setRecordDate(DateUtil.parseDateTime(strDeathDiscussionVO.getRecordDate()));//病历日期
  91. strDeathDiscussion.setWholeData(columnMap);
  92. //判断数据库中是否存在,不存在insert
  93. if(isExist(strDeathDiscussion)){
  94. strDeathDiscussion.setGmtCreate(new Date());//记录创建时间
  95. this.save(strDeathDiscussion);
  96. }else{
  97. strDeathDiscussion.setGmtModified(new Date());//记录修改时间
  98. this.update(strDeathDiscussion,new QueryWrapper<StrDeathDiscussion>()
  99. .eq("rec_id", strDeathDiscussion.getRecId())
  100. .eq("hospital_id", strDeathDiscussion.getHospitalId())
  101. .eq("behospital_code", strDeathDiscussion.getBehospitalCode()));
  102. }
  103. }catch (Exception e){
  104. log.error(e.getMessage(),e);
  105. aMedAbnormalInfoFacade.saveAbnormalInfo("死亡病例讨论记录",strDeathDiscussion.getRecId(), JSON.toJSONString(entityMap),"",e.getMessage());
  106. }
  107. }
  108. public Boolean isExist(StrDeathDiscussion strDeathDiscussion){
  109. Boolean flag=true;
  110. int count = this.baseMapper.selectCount(new QueryWrapper<StrDeathDiscussion>()
  111. .eq("rec_id", strDeathDiscussion.getRecId())
  112. .eq("hospital_id", strDeathDiscussion.getHospitalId())
  113. .eq("behospital_code", strDeathDiscussion.getBehospitalCode()));
  114. if(count>0){
  115. flag=false;
  116. }
  117. return flag;
  118. }
  119. /**
  120. * @Description:死亡病例讨论记录-结构化-独立入口
  121. * @Author:liuqq
  122. * @time: ${DATE} ${TIME}
  123. **/
  124. public RespDTO execDealData(List<StrDeathDiscussionVO> list){
  125. try{
  126. if(list!=null && list.size()>0){
  127. //循环验证数据有效性
  128. for (StrDeathDiscussionVO strDeathDiscussionVO:list) {
  129. if("".equals(strDeathDiscussionVO.getRecId())) {
  130. return RespDTO.onError("请输入记录编号!");
  131. }else if(strDeathDiscussionVO.getHospitalId()==null){
  132. return RespDTO.onError("请输入医院编码!");
  133. }else if("".equals(strDeathDiscussionVO.getBehospitalCode())){
  134. return RespDTO.onError("请输入病人住院编码!");
  135. }
  136. }
  137. //初始、格式化数据
  138. List<StrDeathDiscussion> strDeathDiscussionList= Lists.newArrayList();
  139. execute(strDeathDiscussionList);
  140. if(logSwitch){
  141. strDeathDiscussionList.forEach(s->{
  142. aMedAbnormalInfoFacade.saveAbnormalInfo("结构化-死亡病例讨论记录-正常", s.getRecId(), JSON.toJSONString(s), "", "");
  143. });
  144. }
  145. return RespDTO.onSuc("操作正常!");
  146. }else{
  147. return RespDTO.onError("未接收到数据!");
  148. }
  149. }catch (Exception e){
  150. log.error(e.getMessage(),e);
  151. if(list!=null && list.size()>0) {
  152. list.forEach(s->{
  153. aMedAbnormalInfoFacade.saveAbnormalInfo("结构化-死亡病例讨论记录-异常", s.getRecId(), JSON.toJSONString(list), "", e.getMessage());
  154. });
  155. }
  156. return RespDTO.onError("数据处理异常,详情查看日志表");
  157. }
  158. }
  159. private List<StrDeathDiscussion> initData(List<StrDeathDiscussionVO> list) throws Exception{
  160. List<StrDeathDiscussion> tList=Lists.newArrayList();
  161. for (StrDeathDiscussionVO s:list) {
  162. StrDeathDiscussion t=new StrDeathDiscussion();
  163. BeanUtils.copyProperties(s,t);
  164. if(StringUtil.isNotEmpty(s.getRecordDate())){
  165. t.setRecordDate(DateUtil.parseDateTime(s.getRecordDate()));//病历日期
  166. }
  167. if(StringUtil.isNotEmpty(s.getDeathDate())){
  168. t.setDeathDate(DateUtil.parseDateTime(s.getDeathDate()));//死亡日期
  169. }
  170. if(StringUtil.isNotEmpty(s.getDiscussDate())){
  171. t.setDiscussDate(DateUtil.parseDateTime(s.getDiscussDate()));//讨论时间
  172. }
  173. if(StringUtil.isNotEmpty(s.getRecDate())){
  174. t.setRecDate(DateUtil.parseDateTime(s.getRecDate()));//记录时间
  175. }
  176. if(StringUtil.isNotEmpty(s.getAuditDate())){
  177. t.setAuditDate(DateUtil.parseDateTime(s.getAuditDate()));//审核时间
  178. }
  179. Map<String, String> columnMap=columnFacade.getColumn(CacheKeyEnum.DEATH_DISCUSSION.getName());
  180. Map<String, Object> entityMap=MapUtil.objectToMap(s);
  181. Map<String, Object> wholeMap=MapUtil.objcetKeyConvert(columnMap,entityMap);
  182. //t.setWholeData(JSON.toJSONString(wholeMap));
  183. tList.add(t);
  184. }
  185. return tList;
  186. }
  187. public void execute(List<StrDeathDiscussion> list){
  188. List<StrDeathDiscussion> addE = Lists.newLinkedList();
  189. List<StrDeathDiscussion> updateE = Lists.newLinkedList();
  190. if (list != null && list.size() > 0) {
  191. list.stream().forEach(s -> {
  192. StrDeathDiscussion strDeathDiscussion = this.getOne(new QueryWrapper<StrDeathDiscussion>()
  193. .eq("is_deleted", IsDeleteEnum.N.getKey())
  194. .eq("rec_id", s.getRecId())
  195. .eq("hospital_id", s.getHospitalId())
  196. .eq("behospital_code",s.getBehospitalCode()), false);
  197. if (strDeathDiscussion != null) {
  198. s.setGmtModified(new Date());
  199. updateE.add(s);
  200. } else {
  201. s.setGmtCreate(new Date());
  202. addE.add(s);
  203. }
  204. });
  205. }
  206. if(addE.size()>0){
  207. strDeathDiscussionService.saveBatch(addE);
  208. }
  209. if(updateE.size()>0){
  210. this.baseMapper.updateBatchByKey(updateE);
  211. }
  212. }
  213. }