Bladeren bron

搜索未添加的疾病医学术语名称

wangfeng 4 jaren geleden
bovenliggende
commit
150f14a9b1

+ 309 - 305
cdssman-service/src/main/java/com/diagbot/facade/RelationContactFacade.java

@@ -1,305 +1,309 @@
-package com.diagbot.facade;
-
-import com.baomidou.dynamic.datasource.annotation.DS;
-import com.baomidou.dynamic.datasource.annotation.DSTransactional;
-import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
-import com.diagbot.client.UserServiceClient;
-import com.diagbot.dto.*;
-import com.diagbot.entity.KlConcept;
-import com.diagbot.entity.KlRelation;
-import com.diagbot.entity.KlRelationOrder;
-import com.diagbot.enums.IsDeleteEnum;
-import com.diagbot.enums.LexiconEnum;
-import com.diagbot.service.KlRelationService;
-import com.diagbot.service.impl.KlRelationOrderServiceImpl;
-import com.diagbot.service.impl.KlRelationServiceImpl;
-import com.diagbot.util.DateUtil;
-import com.diagbot.util.ListUtil;
-import com.diagbot.util.UserUtils;
-import com.diagbot.vo.*;
-import com.google.common.collect.Lists;
-import com.google.common.collect.Maps;
-import org.apache.commons.collections4.MapUtils;
-import org.apache.commons.lang3.StringUtils;
-import org.springframework.beans.factory.annotation.Autowired;
-import org.springframework.beans.factory.annotation.Qualifier;
-import org.springframework.stereotype.Component;
-
-import javax.validation.constraints.NotBlank;
-import javax.validation.constraints.NotNull;
-import java.util.ArrayList;
-import java.util.Date;
-import java.util.List;
-import java.util.Map;
-import java.util.stream.Collectors;
-
-/**
- * @author kwz
- * @date 2021/3/3
- * @time 15:42
- */
-@Component
-public class RelationContactFacade extends KlRelationServiceImpl {
-    @Autowired
-    private UserServiceClient userServiceClient;
-    @Autowired
-    private KlConceptFacade klConceptFacade;
-    @Autowired
-    private KlRelationOrderFacade klRelationOrderFacade;
-    @Autowired
-    @Qualifier("klRelationServiceImpl")
-    private KlRelationService klRelationService;
-    @Autowired
-    @Qualifier("klRelationOrderServiceImpl")
-    private KlRelationOrderServiceImpl klRelationOrderServiceImpl;
-    @Autowired
-    KlDiseaseFacade klDiseaseFacade;
-
-
-
-    @DS("med")
-    @DSTransactional
-    public Boolean addRelation(List<KlRelationSaveVO> klRelationSaveVOs) {
-        if (ListUtil.isNotEmpty(klRelationSaveVOs)) {
-            KlRelationSaveVO klRelationSaveVO = klRelationSaveVOs.get(0);
-            Long sid = klRelationSaveVO.getSid();
-            List<Long> conceptid = Lists.newArrayList(sid);
-            Integer rid = klRelationSaveVO.getRid();
-            List<Long> sids = new ArrayList<>();
-            List<RelationNameDTO> relationNameDTOs = this.getRelationNameDTOs(conceptid, rid);
-            if (ListUtil.isNotEmpty(relationNameDTOs)) {
-                for (RelationNameDTO red : relationNameDTOs) {
-                    Long startId = red.getStartId();
-                    Long medId = red.getEndId();
-                    if (!sids.contains(startId)) {
-                        sids.add(startId);
-                    }
-                    if (!sids.contains(medId)) {
-                        sids.add(medId);
-                    }
-                }
-            }
-            List<KlRelation> relationList = this.list(new QueryWrapper<KlRelation>()
-                    .in("start_id", sids)
-                    .eq("relation_id", rid));
-            List<Long> ids = relationList.stream().map(x -> x.getId()).collect(Collectors.toList());
-            //先删除
-            if (ListUtil.isNotEmpty(ids)) {
-                this.removeByIds(ids);
-
-                QueryWrapper<KlRelationOrder> relationOrderQe = new QueryWrapper<>();
-                relationOrderQe.in("t_relation_id", ids);
-                klRelationOrderFacade.remove(relationOrderQe);
-            }
-            List<List<KlRelation>> relationGroupList = relationDataForAdd(klRelationSaveVOs);
-
-            Date now = DateUtil.now();
-            List<KlRelation> relationLists = Lists.newArrayList();
-            relationGroupList.forEach(i -> {
-                i.forEach(j -> {
-                    j.setGmtCreate(now);
-                    j.setModifier(UserUtils.getCurrentPrincipleID());
-                    j.setGmtModified(now);
-                    relationLists.add(j);
-                });
-            });
-            klRelationService.saveBatch(relationLists);
-
-            List<KlRelationOrder> relationOrderList = Lists.newArrayList();
-            relationGroupList.forEach(i -> {
-                int orderNo = 0;
-                for (KlRelation j : i) {
-                    orderNo++;
-                    KlRelationOrder relationOrder = new KlRelationOrder();
-                    relationOrder.setOrderNo(orderNo);
-                    relationOrder.settRelationId(j.getId());
-                    relationOrder.setGmtCreate(now);
-                    relationOrder.setGmtModified(now);
-//                    relationOrder.setCreator(currentUser);
-                    relationOrder.setModifier(UserUtils.getCurrentPrincipleID());
-                    relationOrderList.add(relationOrder);
-                }
-            });
-            klRelationOrderServiceImpl.saveBatch(relationOrderList);
-
-        }
-
-        return true;
-    }
-
-
-    @DS("med")
-    @DSTransactional
-    public Boolean saveRelation(List<KlRelationSaveVO> klRelationSaveVOs) {
-        if (ListUtil.isNotEmpty(klRelationSaveVOs)) {
-            List<List<KlRelation>> relationGroupList = Lists.newArrayList();
-            KlRelationSaveVO klRelationSaveVO = klRelationSaveVOs.get(0);
-            Long sid = klRelationSaveVO.getSid();
-            List<KlRelation> klRelations = this.list(new QueryWrapper<KlRelation>()
-                    .eq("start_id", sid));
-            List<Long> ids = klRelations.stream().map(x -> x.getId()).collect(Collectors.toList());
-            //先删除
-            if (ListUtil.isNotEmpty(ids)) {
-                this.removeByIds(ids);
-                QueryWrapper<KlRelationOrder> relationOrderQe = new QueryWrapper<>();
-                relationOrderQe.in("t_relation_id", ids);
-                klRelationOrderFacade.remove(relationOrderQe);
-            }
-            for (KlRelationSaveVO kls : klRelationSaveVOs) {
-                @NotNull(message = "概念开始id必传") Long sid1 = kls.getSid();
-                @NotNull(message = "关系id必传") Integer rid = kls.getRid();
-                List<Long> eids = kls.getEids();
-                if (ListUtil.isNotEmpty(eids)) {
-                    List<KlRelation> collect = eids.stream().map(x -> {
-                        KlRelation klRelation = new KlRelation();
-                        klRelation.setEndId(x);
-                        klRelation.setRelationId(rid);
-                        klRelation.setStartId(sid1);
-                        klRelation.setStatus(1);
-                        return klRelation;
-                    }).collect(Collectors.toList());
-                    relationGroupList.add(collect);
-                }
-            }
-            Date now = DateUtil.now();
-            List<KlRelation> relationLists = Lists.newArrayList();
-            relationGroupList.forEach(i -> {
-                i.forEach(j -> {
-                    j.setGmtCreate(now);
-                    j.setModifier(UserUtils.getCurrentPrincipleID());
-                    j.setGmtModified(now);
-                    relationLists.add(j);
-                });
-            });
-            klRelationService.saveBatch(relationLists);
-
-            List<KlRelationOrder> relationOrderList = Lists.newArrayList();
-            relationGroupList.forEach(i -> {
-                int orderNo = 0;
-                for (KlRelation j : i) {
-                    orderNo++;
-                    KlRelationOrder relationOrder = new KlRelationOrder();
-                    relationOrder.setOrderNo(orderNo);
-                    relationOrder.settRelationId(j.getId());
-                    relationOrder.setGmtCreate(now);
-                    relationOrder.setGmtModified(now);
-                    relationOrder.setModifier(UserUtils.getCurrentPrincipleID());
-                    relationOrderList.add(relationOrder);
-                }
-            });
-            klRelationOrderServiceImpl.saveBatch(relationOrderList);
-
-
-        }
-        return true;
-    }
-
-    private List<List<KlRelation>> relationDataForAdd(List<KlRelationSaveVO> klRelationSaveVOs) {
-        List<List<KlRelation>> relationList = Lists.newArrayList();
-        Map<String, List<KlRelation>> relationMap = Maps.newHashMap();
-        if (ListUtil.isNotEmpty(klRelationSaveVOs)) {
-
-            for (KlRelationSaveVO kls : klRelationSaveVOs) {
-                Long sid = kls.getSid();
-                Integer rid = kls.getRid();
-                Long eid = kls.getEid();
-                Integer srid = kls.getSrid();
-                List<Long> eids = kls.getEids();
-                if (relationMap.containsKey(sid.toString() + "&" + rid.toString())) {
-                    List<KlRelation> klRelations_big = relationMap.get(sid.toString() + "&" + rid.toString());
-                    KlRelation klRelation = new KlRelation();
-                    klRelation.setStartId(sid);
-                    klRelation.setRelationId(rid);
-                    klRelation.setEndId(eid);
-                    klRelation.setStatus(1);
-                    klRelations_big.add(klRelation);
-                    relationMap.put(sid.toString() + "&" + rid.toString(), klRelations_big);
-                } else {
-                    List<KlRelation> klRelations_big = Lists.newArrayList();
-                    KlRelation klRelation = new KlRelation();
-                    klRelation.setStartId(sid);
-                    klRelation.setRelationId(rid);
-                    klRelation.setEndId(eid);
-                    klRelation.setStatus(1);
-                    klRelations_big.add(klRelation);
-                    relationMap.put(sid.toString() + "&" + rid.toString(), klRelations_big);
-                }
-                if (srid != null && ListUtil.isNotEmpty(eids)) {
-                    List<KlRelation> klRelations_sub = Lists.newArrayList();
-                    for (Long id : eids) {
-                        KlRelation klRelation = new KlRelation();
-                        klRelation.setStartId(eid);
-                        klRelation.setRelationId(srid);
-                        klRelation.setEndId(id);
-                        klRelation.setStatus(1);
-                        klRelations_sub.add(klRelation);
-                    }
-                    relationMap.put(eid.toString() + "&" + srid.toString(), klRelations_sub);
-                }
-            }
-        }
-        if (MapUtils.isNotEmpty(relationMap)) {
-            relationMap.forEach((x, y) -> {
-                relationList.add(y);
-            });
-        }
-
-        return relationList;
-    }
-
-
-
-    /**
-     * 删除某个诊断依据
-     * @param diseaseDeleteVO
-     * @return
-     */
-    @DS("med")
-    @DSTransactional
-    public Boolean deleteRelation(DiseaseDeleteVO diseaseDeleteVO) {
-        String disName = diseaseDeleteVO.getDisName();
-        if(StringUtils.isNotBlank(disName)){
-            List<KlConcept> klConcepts = klConceptFacade.list(new QueryWrapper<KlConcept>()
-                    .eq("is_deleted", IsDeleteEnum.N.getKey())
-                    .eq("lib_name", disName.trim())
-                    .eq("lib_type", 100));
-            List<Long> ids = klConcepts.stream().map(x -> x.getId()).collect(Collectors.toList());
-            List<Integer> relations = Lists.newArrayList(501, 502, 503, 504, 505, 506, 507, 508);
-            List<KlRelation> klRelations = this.list(new QueryWrapper<KlRelation>()
-                    .eq("is_deleted", IsDeleteEnum.N.getKey())
-                    .in(ListUtil.isNotEmpty(ids),"start_id", ids)
-                    .in(ListUtil.isNotEmpty(relations),"relation_id", relations));
-            List<Long> kids = klRelations.stream().map(x -> x.getId()).collect(Collectors.toList());
-            this.removeByIds(kids);
-            QueryWrapper<KlRelationOrder> relationOrderQe = new QueryWrapper<>();
-            relationOrderQe.in(ListUtil.isNotEmpty(kids),"t_relation_id", kids);
-            klRelationOrderFacade.remove(relationOrderQe);
-        }
-
-        return true;
-    }
-
-    /**
-     * 新增诊断依据
-     * @param diseaseDeleteVO
-     * @return
-     */
-    public List<KlConcept> addDisease(DiseaseDeleteVO diseaseDeleteVO) {
-        List<KlConcept> diseaseAll = klDiseaseFacade.getDiseaseAll(diseaseDeleteVO);
-        return diseaseAll;
-    }
-
-    public List<String> searchAndPosition(GetAllForRelationVO getAllForRelationVO) {
-        List<String> names = Lists.newArrayList();
-        String name = getAllForRelationVO.getName();
-        Long typeId = getAllForRelationVO.getTypeId();
-        List<KlConcept> klConcepts = klConceptFacade.list(new QueryWrapper<KlConcept>()
-                .eq("is_deleted", IsDeleteEnum.N.getKey())
-                .like("lib_name", name.trim())
-                .eq("lib_type", typeId));
-        names = klConcepts.stream().map(x -> x.getLibName()).collect(Collectors.toList());
-
-        return names;
-
-    }
-}
+package com.diagbot.facade;
+
+import com.baomidou.dynamic.datasource.annotation.DS;
+import com.baomidou.dynamic.datasource.annotation.DSTransactional;
+import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
+import com.diagbot.client.UserServiceClient;
+import com.diagbot.dto.*;
+import com.diagbot.entity.KlConcept;
+import com.diagbot.entity.KlRelation;
+import com.diagbot.entity.KlRelationOrder;
+import com.diagbot.enums.IsDeleteEnum;
+import com.diagbot.enums.LexiconEnum;
+import com.diagbot.service.KlRelationService;
+import com.diagbot.service.impl.KlRelationOrderServiceImpl;
+import com.diagbot.service.impl.KlRelationServiceImpl;
+import com.diagbot.util.DateUtil;
+import com.diagbot.util.ListUtil;
+import com.diagbot.util.UserUtils;
+import com.diagbot.vo.*;
+import com.google.common.collect.Lists;
+import com.google.common.collect.Maps;
+import org.apache.commons.collections4.MapUtils;
+import org.apache.commons.lang3.StringUtils;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.beans.factory.annotation.Qualifier;
+import org.springframework.stereotype.Component;
+
+import javax.validation.constraints.NotBlank;
+import javax.validation.constraints.NotNull;
+import java.util.ArrayList;
+import java.util.Date;
+import java.util.List;
+import java.util.Map;
+import java.util.stream.Collectors;
+
+/**
+ * @author kwz
+ * @date 2021/3/3
+ * @time 15:42
+ */
+@Component
+public class RelationContactFacade extends KlRelationServiceImpl {
+    @Autowired
+    private UserServiceClient userServiceClient;
+    @Autowired
+    private KlConceptFacade klConceptFacade;
+    @Autowired
+    private KlRelationOrderFacade klRelationOrderFacade;
+    @Autowired
+    @Qualifier("klRelationServiceImpl")
+    private KlRelationService klRelationService;
+    @Autowired
+    @Qualifier("klRelationOrderServiceImpl")
+    private KlRelationOrderServiceImpl klRelationOrderServiceImpl;
+    @Autowired
+    KlDiseaseFacade klDiseaseFacade;
+
+
+
+    @DS("med")
+    @DSTransactional
+    public Boolean addRelation(List<KlRelationSaveVO> klRelationSaveVOs) {
+        if (ListUtil.isNotEmpty(klRelationSaveVOs)) {
+            KlRelationSaveVO klRelationSaveVO = klRelationSaveVOs.get(0);
+            Long sid = klRelationSaveVO.getSid();
+            List<Long> conceptid = Lists.newArrayList(sid);
+            Integer rid = klRelationSaveVO.getRid();
+            List<Long> sids = new ArrayList<>();
+            List<RelationNameDTO> relationNameDTOs = this.getRelationNameDTOs(conceptid, rid);
+            if (ListUtil.isNotEmpty(relationNameDTOs)) {
+                for (RelationNameDTO red : relationNameDTOs) {
+                    Long startId = red.getStartId();
+                    Long medId = red.getEndId();
+                    if (!sids.contains(startId)) {
+                        sids.add(startId);
+                    }
+                    if (!sids.contains(medId)) {
+                        sids.add(medId);
+                    }
+                }
+            }
+            List<KlRelation> relationList = this.list(new QueryWrapper<KlRelation>()
+                    .in("start_id", sids)
+                    .eq("relation_id", rid));
+            List<Long> ids = relationList.stream().map(x -> x.getId()).collect(Collectors.toList());
+            //先删除
+            if (ListUtil.isNotEmpty(ids)) {
+                this.removeByIds(ids);
+
+                QueryWrapper<KlRelationOrder> relationOrderQe = new QueryWrapper<>();
+                relationOrderQe.in("t_relation_id", ids);
+                klRelationOrderFacade.remove(relationOrderQe);
+            }
+            List<List<KlRelation>> relationGroupList = relationDataForAdd(klRelationSaveVOs);
+
+            Date now = DateUtil.now();
+            List<KlRelation> relationLists = Lists.newArrayList();
+            relationGroupList.forEach(i -> {
+                i.forEach(j -> {
+                    j.setGmtCreate(now);
+                    j.setModifier(UserUtils.getCurrentPrincipleID());
+                    j.setGmtModified(now);
+                    relationLists.add(j);
+                });
+            });
+            klRelationService.saveBatch(relationLists);
+
+            List<KlRelationOrder> relationOrderList = Lists.newArrayList();
+            relationGroupList.forEach(i -> {
+                int orderNo = 0;
+                for (KlRelation j : i) {
+                    orderNo++;
+                    KlRelationOrder relationOrder = new KlRelationOrder();
+                    relationOrder.setOrderNo(orderNo);
+                    relationOrder.settRelationId(j.getId());
+                    relationOrder.setGmtCreate(now);
+                    relationOrder.setGmtModified(now);
+//                    relationOrder.setCreator(currentUser);
+                    relationOrder.setModifier(UserUtils.getCurrentPrincipleID());
+                    relationOrderList.add(relationOrder);
+                }
+            });
+            klRelationOrderServiceImpl.saveBatch(relationOrderList);
+
+        }
+
+        return true;
+    }
+
+
+    @DS("med")
+    @DSTransactional
+    public Boolean saveRelation(List<KlRelationSaveVO> klRelationSaveVOs) {
+        if (ListUtil.isNotEmpty(klRelationSaveVOs)) {
+            List<List<KlRelation>> relationGroupList = Lists.newArrayList();
+            KlRelationSaveVO klRelationSaveVO = klRelationSaveVOs.get(0);
+            Long sid = klRelationSaveVO.getSid();
+            List<KlRelation> klRelations = this.list(new QueryWrapper<KlRelation>()
+                    .eq("start_id", sid));
+            List<Long> ids = klRelations.stream().map(x -> x.getId()).collect(Collectors.toList());
+            //先删除
+            if (ListUtil.isNotEmpty(ids)) {
+                this.removeByIds(ids);
+                QueryWrapper<KlRelationOrder> relationOrderQe = new QueryWrapper<>();
+                relationOrderQe.in("t_relation_id", ids);
+                klRelationOrderFacade.remove(relationOrderQe);
+            }
+            for (KlRelationSaveVO kls : klRelationSaveVOs) {
+                @NotNull(message = "概念开始id必传") Long sid1 = kls.getSid();
+                @NotNull(message = "关系id必传") Integer rid = kls.getRid();
+                List<Long> eids = kls.getEids();
+                if (ListUtil.isNotEmpty(eids)) {
+                    List<KlRelation> collect = eids.stream().map(x -> {
+                        KlRelation klRelation = new KlRelation();
+                        klRelation.setEndId(x);
+                        klRelation.setRelationId(rid);
+                        klRelation.setStartId(sid1);
+                        klRelation.setStatus(1);
+                        return klRelation;
+                    }).collect(Collectors.toList());
+                    relationGroupList.add(collect);
+                }
+            }
+            Date now = DateUtil.now();
+            List<KlRelation> relationLists = Lists.newArrayList();
+            relationGroupList.forEach(i -> {
+                i.forEach(j -> {
+                    j.setGmtCreate(now);
+                    j.setModifier(UserUtils.getCurrentPrincipleID());
+                    j.setGmtModified(now);
+                    relationLists.add(j);
+                });
+            });
+            klRelationService.saveBatch(relationLists);
+
+            List<KlRelationOrder> relationOrderList = Lists.newArrayList();
+            relationGroupList.forEach(i -> {
+                int orderNo = 0;
+                for (KlRelation j : i) {
+                    orderNo++;
+                    KlRelationOrder relationOrder = new KlRelationOrder();
+                    relationOrder.setOrderNo(orderNo);
+                    relationOrder.settRelationId(j.getId());
+                    relationOrder.setGmtCreate(now);
+                    relationOrder.setGmtModified(now);
+                    relationOrder.setModifier(UserUtils.getCurrentPrincipleID());
+                    relationOrderList.add(relationOrder);
+                }
+            });
+            klRelationOrderServiceImpl.saveBatch(relationOrderList);
+
+
+        }
+        return true;
+    }
+
+    private List<List<KlRelation>> relationDataForAdd(List<KlRelationSaveVO> klRelationSaveVOs) {
+        List<List<KlRelation>> relationList = Lists.newArrayList();
+        Map<String, List<KlRelation>> relationMap = Maps.newHashMap();
+        if (ListUtil.isNotEmpty(klRelationSaveVOs)) {
+
+            for (KlRelationSaveVO kls : klRelationSaveVOs) {
+                Long sid = kls.getSid();
+                Integer rid = kls.getRid();
+                Long eid = kls.getEid();
+                Integer srid = kls.getSrid();
+                List<Long> eids = kls.getEids();
+                if (relationMap.containsKey(sid.toString() + "&" + rid.toString())) {
+                    List<KlRelation> klRelations_big = relationMap.get(sid.toString() + "&" + rid.toString());
+                    KlRelation klRelation = new KlRelation();
+                    klRelation.setStartId(sid);
+                    klRelation.setRelationId(rid);
+                    klRelation.setEndId(eid);
+                    klRelation.setStatus(1);
+                    klRelations_big.add(klRelation);
+                    relationMap.put(sid.toString() + "&" + rid.toString(), klRelations_big);
+                } else {
+                    List<KlRelation> klRelations_big = Lists.newArrayList();
+                    KlRelation klRelation = new KlRelation();
+                    klRelation.setStartId(sid);
+                    klRelation.setRelationId(rid);
+                    klRelation.setEndId(eid);
+                    klRelation.setStatus(1);
+                    klRelations_big.add(klRelation);
+                    relationMap.put(sid.toString() + "&" + rid.toString(), klRelations_big);
+                }
+                if (srid != null && ListUtil.isNotEmpty(eids)) {
+                    List<KlRelation> klRelations_sub = Lists.newArrayList();
+                    for (Long id : eids) {
+                        KlRelation klRelation = new KlRelation();
+                        klRelation.setStartId(eid);
+                        klRelation.setRelationId(srid);
+                        klRelation.setEndId(id);
+                        klRelation.setStatus(1);
+                        klRelations_sub.add(klRelation);
+                    }
+                    relationMap.put(eid.toString() + "&" + srid.toString(), klRelations_sub);
+                }
+            }
+        }
+        if (MapUtils.isNotEmpty(relationMap)) {
+            relationMap.forEach((x, y) -> {
+                relationList.add(y);
+            });
+        }
+
+        return relationList;
+    }
+
+
+
+    /**
+     * 删除某个诊断依据
+     * @param diseaseDeleteVO
+     * @return
+     */
+    @DS("med")
+    @DSTransactional
+    public Boolean deleteRelation(DiseaseDeleteVO diseaseDeleteVO) {
+        String disName = diseaseDeleteVO.getDisName();
+        if(StringUtils.isNotBlank(disName)){
+            List<KlConcept> klConcepts = klConceptFacade.list(new QueryWrapper<KlConcept>()
+                    .eq("is_deleted", IsDeleteEnum.N.getKey())
+                    .eq("lib_name", disName.trim())
+                    .eq("lib_type", 100));
+            List<Long> ids = klConcepts.stream().map(x -> x.getId()).collect(Collectors.toList());
+            List<Integer> relations = Lists.newArrayList(501, 502, 503, 504, 505, 506, 507, 508);
+            List<KlRelation> klRelations = this.list(new QueryWrapper<KlRelation>()
+                    .eq("is_deleted", IsDeleteEnum.N.getKey())
+                    .in(ListUtil.isNotEmpty(ids),"start_id", ids)
+                    .in(ListUtil.isNotEmpty(relations),"relation_id", relations));
+            List<Long> kids = klRelations.stream().map(x -> x.getId()).collect(Collectors.toList());
+            this.removeByIds(kids);
+            QueryWrapper<KlRelationOrder> relationOrderQe = new QueryWrapper<>();
+            relationOrderQe.in(ListUtil.isNotEmpty(kids),"t_relation_id", kids);
+            klRelationOrderFacade.remove(relationOrderQe);
+        }
+
+        return true;
+    }
+
+    /**
+     * 新增诊断依据
+     * @param diseaseDeleteVO
+     * @return
+     */
+    public List<KlConcept> addDisease(DiseaseDeleteVO diseaseDeleteVO) {
+        List<KlConcept> diseaseAll = klDiseaseFacade.getDiseaseAll(diseaseDeleteVO);
+        return diseaseAll;
+    }
+
+    public List<String> searchAndPosition(GetAllForRelationVO getAllForRelationVO) {
+        List<String> names = Lists.newArrayList();
+        String name = getAllForRelationVO.getName();
+        Long typeId = getAllForRelationVO.getTypeId();
+        List<KlConcept> klConcepts = klConceptFacade.list(new QueryWrapper<KlConcept>()
+                .eq("is_deleted", IsDeleteEnum.N.getKey())
+                .like("lib_name", name.trim())
+                .eq("lib_type", typeId));
+        names = klConcepts.stream().map(x -> x.getLibName()).collect(Collectors.toList());
+
+        return names;
+
+    }
+
+    public List<GetAllForRelationDTO> findDisNameAlls(DisNameFindVO disNameFindVO) {
+        return  findDisNameAll(disNameFindVO);
+    }
+}

+ 4 - 0
cdssman-service/src/main/java/com/diagbot/mapper/KlRelationMapper.java

@@ -1,10 +1,12 @@
 package com.diagbot.mapper;
 
+import com.diagbot.dto.GetAllForRelationDTO;
 import com.diagbot.dto.RelationDTO;
 import com.diagbot.dto.RelationNameDTO;
 import com.diagbot.dto.RelationNodeDTO;
 import com.diagbot.entity.KlRelation;
 import com.baomidou.mybatisplus.core.mapper.BaseMapper;
+import com.diagbot.vo.DisNameFindVO;
 import com.diagbot.vo.KlRelationVO;
 import com.diagbot.vo.RelationVO;
 import org.apache.ibatis.annotations.Param;
@@ -31,4 +33,6 @@ public interface KlRelationMapper extends BaseMapper<KlRelation> {
     List<RelationDTO> getRelations(RelationVO relationVO);
 
     List<RelationNameDTO> getRelationNameDTOs(@Param(value="conceptIds")List<Long> conceptIds,@Param(value="relationId")Integer relationId);
+
+    List<GetAllForRelationDTO> findDisNameAll(DisNameFindVO disNameFindVO);
 }

+ 4 - 0
cdssman-service/src/main/java/com/diagbot/service/KlRelationService.java

@@ -1,10 +1,12 @@
 package com.diagbot.service;
 
+import com.diagbot.dto.GetAllForRelationDTO;
 import com.diagbot.dto.MedClassMedDTO;
 import com.diagbot.dto.RelationDTO;
 import com.diagbot.dto.RelationNameDTO;
 import com.diagbot.entity.KlRelation;
 import com.baomidou.mybatisplus.extension.service.IService;
+import com.diagbot.vo.DisNameFindVO;
 import com.diagbot.vo.KlRelationVO;
 import com.diagbot.vo.RelationVO;
 import io.swagger.models.auth.In;
@@ -25,4 +27,6 @@ public interface KlRelationService extends IService<KlRelation> {
     List<RelationDTO> getRelations(RelationVO relationVO);
 
     List<RelationNameDTO> getRelationNameDTOs(List<Long> conceptIds, Integer relationId);
+
+    List<GetAllForRelationDTO> findDisNameAll(DisNameFindVO disNameFindVO);
 }

+ 7 - 0
cdssman-service/src/main/java/com/diagbot/service/impl/KlRelationServiceImpl.java

@@ -2,12 +2,14 @@ package com.diagbot.service.impl;
 
 import com.baomidou.dynamic.datasource.annotation.DS;
 import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
+import com.diagbot.dto.GetAllForRelationDTO;
 import com.diagbot.dto.MedClassMedDTO;
 import com.diagbot.dto.RelationDTO;
 import com.diagbot.dto.RelationNameDTO;
 import com.diagbot.entity.KlRelation;
 import com.diagbot.mapper.KlRelationMapper;
 import com.diagbot.service.KlRelationService;
+import com.diagbot.vo.DisNameFindVO;
 import com.diagbot.vo.KlRelationVO;
 import com.diagbot.vo.RelationVO;
 import org.apache.ibatis.annotations.Param;
@@ -38,4 +40,9 @@ public class KlRelationServiceImpl extends ServiceImpl<KlRelationMapper, KlRelat
     public List<RelationNameDTO> getRelationNameDTOs(List<Long> conceptIds,Integer relationId) {
         return baseMapper.getRelationNameDTOs(conceptIds,relationId);
     }
+
+    @Override
+    public List<GetAllForRelationDTO> findDisNameAll(DisNameFindVO disNameFindVO) {
+        return baseMapper.findDisNameAll(disNameFindVO);
+    }
 }

+ 20 - 0
cdssman-service/src/main/java/com/diagbot/vo/DisNameFindVO.java

@@ -0,0 +1,20 @@
+package com.diagbot.vo;
+
+import io.swagger.annotations.ApiModelProperty;
+import lombok.Getter;
+import lombok.Setter;
+
+import javax.validation.constraints.NotBlank;
+
+/**
+ * @author wangfeng
+ * @Description:
+ * @date 2021-03-24 9:39
+ */
+@Setter
+@Getter
+public class DisNameFindVO {
+    @ApiModelProperty(value="名称")
+    @NotBlank(message = "请输入搜索名称")
+    private String diseaseName;
+}

+ 9 - 0
cdssman-service/src/main/java/com/diagbot/web/KlDiseaseController.java

@@ -100,4 +100,13 @@ public class KlDiseaseController {
         return RespDTO.onSuc(klConcepts);
     }
 
+    @ApiOperation(value = "搜索未添加的疾病医学术语名称[by:wangfeng]",
+            notes = "diseaseName:疾病医学术语名称 <br>")
+    @PostMapping("/findDisName")
+    @SysLogger("findDisName")
+    public RespDTO<GetAllForRelationDTO> findDisNames(@Valid @RequestBody DisNameFindVO disNameFindVO) {
+        List<GetAllForRelationDTO> klConcepts = relationContactFacade.findDisNameAlls(disNameFindVO);
+        return RespDTO.onSuc(klConcepts);
+    }
+
 }

+ 68 - 23
cdssman-service/src/main/resources/mapper/KlRelationMapper.xml

@@ -4,16 +4,16 @@
 
     <!-- 通用查询映射结果 -->
     <resultMap id="BaseResultMap" type="com.diagbot.entity.KlRelation">
-        <id column="id" property="id" />
-        <result column="is_deleted" property="isDeleted" />
-        <result column="gmt_create" property="gmtCreate" />
-        <result column="gmt_modified" property="gmtModified" />
-        <result column="creator" property="creator" />
-        <result column="modifier" property="modifier" />
-        <result column="start_id" property="startId" />
-        <result column="relation_id" property="relationId" />
-        <result column="end_id" property="endId" />
-        <result column="status" property="status" />
+        <id column="id" property="id"/>
+        <result column="is_deleted" property="isDeleted"/>
+        <result column="gmt_create" property="gmtCreate"/>
+        <result column="gmt_modified" property="gmtModified"/>
+        <result column="creator" property="creator"/>
+        <result column="modifier" property="modifier"/>
+        <result column="start_id" property="startId"/>
+        <result column="relation_id" property="relationId"/>
+        <result column="end_id" property="endId"/>
+        <result column="status" property="status"/>
     </resultMap>
 
     <select id="getMedClassMedList" resultType="com.diagbot.dto.MedClassMedDTO">
@@ -43,20 +43,20 @@
 
     <select id="getRelations" parameterType="com.diagbot.vo.RelationVO" resultType="com.diagbot.dto.RelationDTO">
         SELECT
-            a.id AS sId,
-            a.lib_name AS sName,
-            a.lib_type AS sType,
-            b.relation_id AS rId,
-            c.id AS eId,
-            c.lib_name AS eName,
-            c.lib_type AS eType
+        a.id AS sId,
+        a.lib_name AS sName,
+        a.lib_type AS sType,
+        b.relation_id AS rId,
+        c.id AS eId,
+        c.lib_name AS eName,
+        c.lib_type AS eType
         FROM
-            kl_concept a,
-            kl_relation b,
-            kl_concept c,
-            kl_relation_order d
+        kl_concept a,
+        kl_relation b,
+        kl_concept c,
+        kl_relation_order d
         WHERE
-            a.is_deleted = 'N'
+        a.is_deleted = 'N'
         AND b.is_deleted = 'N'
         AND c.is_deleted = 'N'
         AND a.id = b.start_id
@@ -76,7 +76,7 @@
         AND b.id = d.t_relation_id
         AND d.is_deleted = 'N'
         ORDER BY
-            d.order_no
+        d.order_no
     </select>
 
     <select id="getRelationNodeDTOs" resultType="com.diagbot.dto.RelationNodeDTO">
@@ -151,5 +151,50 @@
         WHERE
         m.medId = kc.id
     </select>
+    <select id="findDisNameAll" resultType="com.diagbot.dto.GetAllForRelationDTO">
+        SELECT DISTINCT
+        con.id AS conceptId,
+        con.lib_name AS conceptName,
+        con.lib_type AS libType,
+        le.name AS conceptNameType
+        FROM
+        (
+        SELECT
+        b.id AS conceptId,
+        b.lib_name AS disName
+        FROM
+        `kl_relation` a,
+        kl_concept b
+        WHERE
+        a.is_deleted = 'N'
+        AND b.is_deleted = 'N'
+        AND a.status = 1
+        AND b.status = 1
+        AND a.start_id = b.id
+        AND b.lib_type=100
+        AND a.relation_id IN (
+        501,
+        502,
+        503,
+        504,
+        505,
+        506,
+        507,
+        508
+        )
+        GROUP BY b.id
+        ) re
+        RIGHT JOIN kl_concept con
+        ON re.conceptId = con.id
+        LEFT JOIN kl_lexicon le ON con.`lib_type` = le.`code`
+        WHERE con.is_deleted = "N"
+        AND con.lib_type = 100
+        AND con.status= 1
+        <if test="diseaseName != null and diseaseName != ''">
+            AND UPPER(con.lib_name) LIKE CONCAT('%', UPPER(trim(#{diseaseName})), '%')
+        </if>
+        ORDER BY con.lib_name DESC
+
+    </select>
 
 </mapper>