From 2b39b654975aa9cb40254f20e545b9f389a82de7 Mon Sep 17 00:00:00 2001 From: zjh <1084500556@qq.com> Date: 星期五, 24 一月 2025 18:24:33 +0800 Subject: [PATCH] zjh20250124 --- ltkj-admin/src/main/java/com/ltkj/web/config/timer/DefaultScheduled.java | 4 ltkj-common/src/main/java/com/ltkj/common/enums/DataSourceType.java | 2 ltkj-admin/pom.xml | 7 + ltkj-hosp/src/main/java/com/ltkj/hosp/domain/TjOrderDetail.java | 3 ltkj-admin/src/main/java/com/ltkj/web/controller/his/HisPDFUtil.java | 244 +++++++++++++++++++--------------- ltkj-admin/src/main/java/com/ltkj/web/controller/system/TjCheckController.java | 28 +++- ltkj-framework/src/main/java/com/ltkj/framework/config/DruidConfig.java | 51 +++++++ ltkj-hosp/src/main/java/com/ltkj/hosp/domain/TjOrderRemark.java | 3 ltkj-hosp/src/main/java/com/ltkj/hosp/mapper/TestMapper.java | 36 +++++ 9 files changed, 260 insertions(+), 118 deletions(-) diff --git a/ltkj-admin/pom.xml b/ltkj-admin/pom.xml index 5d80b15..37de661 100644 --- a/ltkj-admin/pom.xml +++ b/ltkj-admin/pom.xml @@ -114,6 +114,13 @@ <version>4.0</version> </dependency> + <dependency> + <groupId>com.microsoft.sqlserver</groupId> + <artifactId>mssql-jdbc</artifactId> + <version>10.2.0.jre8</version> <!-- 浣跨敤鏈�鏂扮増鏈� --> + </dependency> + + <!-- Mysql椹卞姩鍖� --> <dependency> <groupId>mysql</groupId> diff --git a/ltkj-admin/src/main/java/com/ltkj/web/config/timer/DefaultScheduled.java b/ltkj-admin/src/main/java/com/ltkj/web/config/timer/DefaultScheduled.java index d2e237f..31b3ce1 100644 --- a/ltkj-admin/src/main/java/com/ltkj/web/config/timer/DefaultScheduled.java +++ b/ltkj-admin/src/main/java/com/ltkj/web/config/timer/DefaultScheduled.java @@ -189,6 +189,8 @@ private void extractedjianyan(String s) { try { List<LtkjHysqd> hysqdList = testMapper.getCcXZxYyLtkjHysqdByLisVi(s); + List<LtkjHysqd> wssq = testMapper.getWsxmLtkjHysqdByLisVi(s); + if(null !=wssq && !wssq.isEmpty())hysqdList.addAll(wssq); if (null != hysqdList && !hysqdList.isEmpty()) { for (LtkjHysqd hysqd : hysqdList) { LtkjHysqd jybgid = ltkjHysqdService.getLtkjHysqdByTjhAndTmh(hysqd.getTjh(), hysqd.getTmh()); @@ -198,6 +200,8 @@ } if (ltkjHysqdService.save(hysqd)) { List<LtkjHybgd> hybgdList = testMapper.getCcXZxYyLtkjHybgdByLisVi(hysqd.getTmh()); + List<LtkjHybgd> wsbg = testMapper.getWsxmLtkjHybgdByLisVi(s); + if(null !=wsbg && !wsbg.isEmpty())hybgdList.addAll(wsbg); ltkjHybgdService.saveBatch(hybgdList); } } diff --git a/ltkj-admin/src/main/java/com/ltkj/web/controller/his/HisPDFUtil.java b/ltkj-admin/src/main/java/com/ltkj/web/controller/his/HisPDFUtil.java index 6877a75..a3fbce1 100644 --- a/ltkj-admin/src/main/java/com/ltkj/web/controller/his/HisPDFUtil.java +++ b/ltkj-admin/src/main/java/com/ltkj/web/controller/his/HisPDFUtil.java @@ -46,6 +46,7 @@ import java.lang.reflect.InvocationTargetException; import java.lang.reflect.Method; import java.math.BigDecimal; +import java.text.Collator; import java.text.SimpleDateFormat; import java.util.*; import java.util.List; @@ -141,7 +142,7 @@ return data; } - public void putData(JSONObject jsonObject, AjaxResult result, String key) { +/* public void putData(JSONObject jsonObject, AjaxResult result, String key) { if (Integer.parseInt(result.get("code").toString()) == 200) { List<Map<String, Object>> data = (List<Map<String, Object>>) result.get("data"); jsonObject.putOpt(key, data); @@ -859,7 +860,7 @@ String outputFileName1 = customer.getCusId() + tjOrder.getTjNumber() + customer.getCusName() + "_鎶ュ憡.pdf"; savePDFFile(outputFileName1, tjOrder, customer, finalOutput); return AjaxResult.success(); - } + }*/ public AjaxResult hisPDFNew2(TjOrder tjOrder, TjCustomer customer, TjReportTemplate tjReportTemplate, TjReportTemplate zongJianYiShiQianMing) throws Exception { String s1 = sysConfigService.selectConfigByKey("tjreport_font_size_second_page_info"); @@ -920,7 +921,23 @@ for (String head : titles) { table.addCell(PdfUtils.createCell(head, defaultFont, Rectangle.BOX, Element.ALIGN_CENTER, 5f, 5f)); } - Map<String, List<CsProVo>> listMap = list.stream().collect(Collectors.groupingBy(i -> i.getDeptId() + "_" + i.getDeptName())); +// Map<String, List<CsProVo>> listMap = list.stream() +// .collect(Collectors.groupingBy(i -> i.getDeptId() + "_" + i.getDeptName())); + Map<String, List<CsProVo>> listMap = list.stream() + .collect(Collectors.groupingBy( + i -> i.getDeptId() + "_" + i.getDeptName(), + TreeMap::new, // 鎸夐敭鎺掑簭 + Collectors.mapping( + i -> i, + Collectors.collectingAndThen( + Collectors.toList(), + l -> l.stream() + .sorted(Comparator.comparing(CsProVo::getDeptId)) // 瀵� List 鎺掑簭 + .collect(Collectors.toList()) + ) + ) + )); + // List<CsProVo> sortedList = list.stream() // .sorted(Comparator.comparingLong(CsProVo::getProId)) // .collect(Collectors.toList()); @@ -1101,6 +1118,9 @@ if (!entry.getKey().equals(proVo.getProId())) continue; List<TjOrderDetail> details = entry.getValue(); if(null !=details && !details.isEmpty()){ + details= details.stream() + .sorted(Comparator.comparing(TjOrderDetail::getProName)) + .collect(Collectors.toList()); boolean isXmWrite = false; int index = 1; int index1 = 1; @@ -2054,7 +2074,7 @@ // document1.add(table); // if (dictHosp.getHospName().equals("婢勫悎鐭垮姟灞�涓績鍖婚櫌") && !value.isEmpty()){ - if (true && !value.isEmpty()) { + if (!value.isEmpty()) { if (value.size() > 1) { if (value.get(0).getPid().equals("1862852701533012001")) { Font remarkFonts = PdfUtils.setFont(DEFAULT_FONT_SIZE); @@ -2175,7 +2195,7 @@ entry.getKey().setRemark(""); } // if (!dictHosp.getHospName().equals("婢勫悎鐭垮姟灞�涓績鍖婚櫌")){ - if (!true) { + if (false) { String remark = "澶囨敞锛�" + entry.getKey().getRemark(); if (entry.getKey().getRemark().length() > 50) { int j = 0; @@ -2202,42 +2222,34 @@ zhuJianYiShi(document1, entry, orderRemark.getCreateTime(), dictHosp); //鍒嗗壊绾� // if (!dictHosp.getHospName().equals("婢勫悎鐭垮姟灞�涓績鍖婚櫌")) { - if (!true) { + if (false) { LineSeparator objectName = new LineSeparator(); document1.add(objectName); } } else { - if (null != one11) { - if (entry.getValue().get(0).getProName().contains(";")) - titleName = entry.getValue().get(0).getProName(); - else titleName = one11.getProName(); - } else { - titleName = entry.getKey().getProName(); - } + if (entry.getValue().get(0).getProName().contains(";")) + titleName = entry.getValue().get(0).getProName(); + else titleName = one11.getProName(); // 璁剧疆鏍囬瀛椾綋鏍峰紡 Font titleFonts = PdfUtils.setFont(DEFAULT_FONT_SIZE); Paragraph paragraph = PdfUtils.setParagraph(titleFonts, titleName); // if (dictHosp.getHospName().equals("婢勫悎鐭垮姟灞�涓績鍖婚櫌")) { - if (true) { - if (StrUtil.isBlank(value.get(0).getProResult()) && (StrUtil.isBlank(value.get(0).getTs()) && StrUtil.isBlank(value.get(0).getSj()))) { - continue; - } - Font titleFont = PdfUtils.setFont(DEFAULT_TITLE_FONT_SIZE); - titleFont.setStyle(Font.BOLD); - PdfPCell cellTitle = new PdfPCell(PdfUtils.setParagraph(titleFont, titleName)); - cellTitle.setBorder(Rectangle.NO_BORDER); - Color color = Color.decode("#B4CDCD"); - cellTitle.setBackgroundColor(new BaseColor(color.getRed(), color.getGreen(), color.getBlue())); // 璁剧疆鑳屾櫙棰滆壊锛堝崄鍏繘鍒� RGB锛� - // 鍒涘缓琛ㄦ牸骞舵坊鍔犲崟鍏冩牸 - PdfPTable tableTitle = new PdfPTable(1); - tableTitle.setWidthPercentage(100); - tableTitle.addCell(cellTitle); - // 灏嗚〃鏍兼坊鍔犲埌鏂囨。涓� - document1.add(tableTitle); - } else { - document1.add(paragraph); + if (StrUtil.isBlank(value.get(0).getProResult()) && (StrUtil.isBlank(value.get(0).getTs()) && StrUtil.isBlank(value.get(0).getSj()))) { + continue; } + Font titleFont = PdfUtils.setFont(DEFAULT_TITLE_FONT_SIZE); + titleFont.setStyle(Font.BOLD); + PdfPCell cellTitle = new PdfPCell(PdfUtils.setParagraph(titleFont, titleName)); + cellTitle.setBorder(Rectangle.NO_BORDER); + Color color = Color.decode("#B4CDCD"); + cellTitle.setBackgroundColor(new BaseColor(color.getRed(), color.getGreen(), color.getBlue())); // 璁剧疆鑳屾櫙棰滆壊锛堝崄鍏繘鍒� RGB锛� + // 鍒涘缓琛ㄦ牸骞舵坊鍔犲崟鍏冩牸 + PdfPTable tableTitle = new PdfPTable(1); + tableTitle.setWidthPercentage(100); + tableTitle.addCell(cellTitle); + // 灏嗚〃鏍兼坊鍔犲埌鏂囨。涓� + document1.add(tableTitle); // String[] titles = {"浣撴椤圭洰", "浣撴缁撴灉", "鍗曚綅"}; // Font headFont = PdfUtils.setFont(9); @@ -2246,7 +2258,7 @@ // document1.add(table); // if (dictHosp.getHospName().equals("婢勫悎鐭垮姟灞�涓績鍖婚櫌") && !value.isEmpty()){ - if (true && !value.isEmpty()) { + if (!value.isEmpty()) { if (value.size() > 1) { if (value.get(0).getPid().equals("1862852701533012001")) { Font remarkFonts = PdfUtils.setFont(DEFAULT_FONT_SIZE); @@ -2493,78 +2505,87 @@ LambdaQueryWrapper<LtkjHybgd> ltkjHybgdLambdaQueryWrapper = new LambdaQueryWrapper<>(); ltkjHybgdLambdaQueryWrapper.eq(LtkjHybgd::getTmh, hysqd.getTmh()); List<LtkjHybgd> hybgds = ltkjHybgdService.list(ltkjHybgdLambdaQueryWrapper); - // 澶х被椤圭洰鍚嶇О - String xmmc = hysqd.getXmmc(); - ArrayList<List<String>> lists = new ArrayList<>(); - HashSet<String> hashSet = new HashSet<>(); - String shsj = ""; - for (LtkjHybgd hybgd : hybgds) { - shsj = hybgd.getShsj(); - // 妫�鏌ラ」鐩� - String jcxm = hybgd.getJcxm() != null ? hybgd.getJcxm().trim() : null; - // 妫�楠岀粨鏋� - String jyjg = hybgd.getJyjg() != null ? hybgd.getJyjg().trim() : null; - // 缁撴灉鍗曚綅 - String jgdw = hybgd.getJgdw() != null ? hybgd.getJgdw().trim() : null; - // 鑼冨洿鍊� - String fwz = hybgd.getFwz() != null ? hybgd.getFwz().trim() : null; - // 妫�楠屽尰甯� -// String jyys = hybgd.getJyys(); - //瀹℃牳鍖荤敓 - String shysmc = hybgd.getShysmc() != null ? hybgd.getShysmc().trim() : null; - // 瀹℃牳鍖诲笀缂栫爜 - String shys = hybgd.getShys() != null ? hybgd.getShys().trim() : null; - String ycbz = ""; + if(null !=hybgds && !hybgds.isEmpty()){ +// hybgds=hybgds.stream().sorted(Comparator.comparing(LtkjHybgd::getJcxm, Collator.getInstance(Locale.CHINA))).collect(Collectors.toList()); +// hybgds = hybgds.stream() +// .sorted(Comparator.comparingInt( +// a -> a.getJcxm().length() // 鏍规嵁鍚嶅瓧鐨勯暱搴︽帓搴� +// )) +// .collect(Collectors.toList()); - if (jyjg != null && StrUtil.isNotBlank(jyjg) && fwz != null && StrUtil.isNotBlank(fwz)) { - try { - String[] fwzs = fwz.split("-"); - BigDecimal min = new BigDecimal(fwzs[0]); - BigDecimal max = new BigDecimal(fwzs[1]); - BigDecimal jyjgval = new BigDecimal(jyjg); - // 姣旇緝妫�楠岀粨鏋滃拰鑼冨洿鍊� - if (jyjgval.compareTo(min) < 0) { - // jyjg 灏忎簬鑼冨洿鏈�灏忓�硷紝娣诲姞涓嬬澶� + // 澶х被椤圭洰鍚嶇О + String xmmc = hysqd.getXmmc(); + ArrayList<List<String>> lists = new ArrayList<>(); + HashSet<String> hashSet = new HashSet<>(); + String shsj = ""; + for (LtkjHybgd hybgd : hybgds) { + shsj = hybgd.getShsj(); + // 妫�鏌ラ」鐩� + String jcxm = hybgd.getJcxm() != null ? hybgd.getJcxm().trim() : null; + // 妫�楠岀粨鏋� + String jyjg = hybgd.getJyjg() != null ? hybgd.getJyjg().trim() : null; + // 缁撴灉鍗曚綅 + String jgdw = hybgd.getJgdw() != null ? hybgd.getJgdw().trim() : null; + // 鑼冨洿鍊� + String fwz = hybgd.getFwz() != null ? hybgd.getFwz().trim() : null; + // 妫�楠屽尰甯� +// String jyys = hybgd.getJyys(); + //瀹℃牳鍖荤敓 + String shysmc = hybgd.getShysmc() != null ? hybgd.getShysmc().trim() : null; + // 瀹℃牳鍖诲笀缂栫爜 + String shys = hybgd.getShys() != null ? hybgd.getShys().trim() : null; + String ycbz = ""; + + if (jyjg != null && StrUtil.isNotBlank(jyjg) && fwz != null && StrUtil.isNotBlank(fwz)) { + try { + String[] fwzs = fwz.split("-"); + BigDecimal min = new BigDecimal(fwzs[0]); + BigDecimal max = new BigDecimal(fwzs[1]); + BigDecimal jyjgval = new BigDecimal(jyjg); + // 姣旇緝妫�楠岀粨鏋滃拰鑼冨洿鍊� + if (jyjgval.compareTo(min) < 0) { + // jyjg 灏忎簬鑼冨洿鏈�灏忓�硷紝娣诲姞涓嬬澶� // jyjg = jyjg + " 鈫�"; - ycbz = "鈫�"; - } else if (jyjgval.compareTo(max) > 0) { - // jyjg 澶т簬鑼冨洿鏈�澶у�硷紝娣诲姞涓婄澶� + ycbz = "鈫�"; + } else if (jyjgval.compareTo(max) > 0) { + // jyjg 澶т簬鑼冨洿鏈�澶у�硷紝娣诲姞涓婄澶� // jyjg = jyjg + " 鈫�"; - ycbz = "鈫�"; + ycbz = "鈫�"; + } + } catch (Exception ignored) { } - } catch (Exception ignored) { } - } // LambdaQueryWrapper<SysUser> queryWrapper = new LambdaQueryWrapper<>(); // queryWrapper.eq(SysUser::getUserName,jyys); // List<SysUser> sysUsers = userService.list(queryWrapper); // if (!sysUsers.isEmpty()) // hashSet.add(sysUsers.get(0).getNickName()); - String key = sysConfigService.selectConfigByKey("is_report_pdf_use_ysqm"); - if (null != shys && null != shysmc && key.equals("Y")) { - hashSet.add(shysmc + "|" + shys); - } else { - if (null != shysmc) hashSet.add(shysmc); + String key = sysConfigService.selectConfigByKey("is_report_pdf_use_ysqm"); + if (null != shys && null != shysmc && key.equals("Y")) { + hashSet.add(shysmc + "|" + shys); + } else { + if (null != shysmc) hashSet.add(shysmc); + } + ArrayList<String> strings = new ArrayList<>(); + strings.add(jcxm); + strings.add(jyjg); + strings.add(ycbz); + strings.add(jgdw); + strings.add(fwz); + strings.add(hybgd.getJcxmid()); + strings.add(hysqd.getXmid()); + lists.add(strings); } - ArrayList<String> strings = new ArrayList<>(); - strings.add(jcxm); - strings.add(jyjg); - strings.add(ycbz); - strings.add(jgdw); - strings.add(fwz); - strings.add(hybgd.getJcxmid()); - strings.add(hysqd.getXmid()); - lists.add(strings); - } - if (!lists.isEmpty()) { - HashMap<String, Object> map = new HashMap<>(); - map.put("data", lists); - map.put("jyys", hashSet); - if (StrUtil.isNotBlank(shsj)) { - shsj = shsj.split(" ")[0]; + if (!lists.isEmpty()) { + HashMap<String, Object> map = new HashMap<>(); + map.put("data", lists); + map.put("jyys", hashSet); + if (StrUtil.isNotBlank(shsj)) { + shsj = shsj.split(" ")[0]; + } + map.put("shsj", shsj); + data.put(xmmc, map); } - map.put("shsj", shsj); - data.put(xmmc, map); } } return data; @@ -2757,16 +2778,9 @@ for (Map.Entry<TjOrderRemark, List<TjPdfVO>> entry : printReport.entrySet()) { List<TjPdfVO> tjPdfVOS = new ArrayList<>(); List<TjOrderDetail> tjOrderDetails = tjOrderDetailService.getDetailByOrderIdAndParId(one.getOrderId(), entry.getKey().getProId()); -// tjOrderDetails = new ArrayList<>(tjOrderDetails.stream() -// .filter(i -> StrUtil.isNotBlank(i.getProResult())) -// .collect(Collectors.toMap( -// TjOrderDetail::getProId, -// i -> i, -// (existing, replacement) -> existing -// )) -// .values()); tjOrderDetails = tjOrderDetails.stream().filter(i -> StrUtil.isNotBlank(i.getProResult())).collect(Collectors.toList()); - tjOrderDetails = new ArrayList<>(tjOrderDetails.stream().collect(Collectors.toMap(TjOrderDetail::getProId, i -> i, (existing, replacement) -> existing)).values()); + tjOrderDetails = new ArrayList<>(tjOrderDetails.stream() + .collect(Collectors.toMap(TjOrderDetail::getProId, i -> i, (existing, replacement) -> existing)).values()); for (TjOrderDetail tjOrderDetail : tjOrderDetails) { TjProject tjProject = projectService.getById(String.valueOf(tjOrderDetail.getProId())); if (null != tjProject && tjProject.getNeedReport().equals("Y")) { @@ -2784,19 +2798,21 @@ } tjPdfVO.setProId(String.valueOf(tjOrderDetail.getProject().getProId())); tjPdfVO.setPid(String.valueOf(tjProject.getProParentId())); - LambdaQueryWrapper<LtkjExamJcbgd> wrapper = new LambdaQueryWrapper<>(); - wrapper.eq(LtkjExamJcbgd::getTjh, tjNumber); - wrapper.eq(LtkjExamJcbgd::getXmdm, String.valueOf(tjOrderDetail.getProject().getProParentId())); -// LtkjExamJcbgd jcbgd = jcbgdService.getOne(wrapper); -// if (jcbgd != null){ -// tjPdfVO.setTs(jcbgd.getYxbx()); -// tjPdfVO.setSj(jcbgd.getBgNr()); -// tjPdfVO.setShys(jcbgd.getShysxm()); -// } +// LambdaQueryWrapper<LtkjExamJcbgd> wrapper = new LambdaQueryWrapper<>(); +// wrapper.eq(LtkjExamJcbgd::getTjh, tjNumber); +// wrapper.eq(LtkjExamJcbgd::getXmdm, String.valueOf(tjOrderDetail.getProject().getProParentId())); tjPdfVOS.add(tjPdfVO); } } } +// if(!tjPdfVOS.isEmpty()){ +// tjPdfVOS=tjPdfVOS.stream().sorted(Comparator.comparing(TjPdfVO::getProName, Collator.getInstance(Locale.CHINA))).collect(Collectors.toList()); +// tjPdfVOS = tjPdfVOS.stream() +// .sorted(Comparator.comparingInt( +// tjPdfVO -> tjPdfVO.getProName().length() // 鏍规嵁鍚嶅瓧鐨勯暱搴︽帓搴� +// )) +// .collect(Collectors.toList()); +// } printReport.put(entry.getKey(), tjPdfVOS); } } @@ -2854,6 +2870,14 @@ } } } +// if(!tjPdfVOS.isEmpty()){ +// tjPdfVOS=tjPdfVOS.stream().sorted(Comparator.comparing(TjPdfVO::getProName, Collator.getInstance(Locale.CHINA))).collect(Collectors.toList()); +// tjPdfVOS = tjPdfVOS.stream() +// .sorted(Comparator.comparingInt( +// tjPdfVO -> tjPdfVO.getProName().length() // 鏍规嵁鍚嶅瓧鐨勯暱搴︽帓搴� +// )) +// .collect(Collectors.toList()); +// } printReport.put(entry.getKey(), tjPdfVOS); } } diff --git a/ltkj-admin/src/main/java/com/ltkj/web/controller/system/TjCheckController.java b/ltkj-admin/src/main/java/com/ltkj/web/controller/system/TjCheckController.java index 06c79bc..ad4524b 100644 --- a/ltkj-admin/src/main/java/com/ltkj/web/controller/system/TjCheckController.java +++ b/ltkj-admin/src/main/java/com/ltkj/web/controller/system/TjCheckController.java @@ -49,6 +49,7 @@ import javax.annotation.Resource; import java.math.BigDecimal; +import java.text.Collator; import java.util.*; import java.util.concurrent.TimeUnit; import java.util.stream.Collectors; @@ -1538,7 +1539,9 @@ tjOrderDetail.setProResult(tjOrderDetail.getProResult()); } - dels.add(tjOrderDetail); + if(remark.getOrgType().equals(tjOrderDetail.getOrgType())){ + dels.add(tjOrderDetail); + } } } String summary = remark.getSummary(); @@ -1551,6 +1554,12 @@ if (dels.isEmpty()) { continue; } + dels=dels.stream().sorted(Comparator.comparing(TjOrderDetail::getProName, Collator.getInstance(Locale.CHINA))).collect(Collectors.toList()); + dels = dels.stream() + .sorted(Comparator.comparingInt( + tjPdfVO -> tjPdfVO.getProName().length() // 鏍规嵁鍚嶅瓧鐨勯暱搴︽帓搴� + )) + .collect(Collectors.toList()); parent.put("sons", dels); parent.put("remark", remark.getRemark()); parent.put("jgbx", remark.getJgbx()); @@ -1685,14 +1694,19 @@ } List<Map<String, Object>> mapList = zongjianyishengchakanyichangxiangmu(tjNum); - List<Map<String, Object>> collect = maps.stream() - .filter(a -> mapList.stream() - .allMatch(b -> a.get("jyjc").equals(b.get("jyjc")))) - .collect(Collectors.toList()); + List<Map<String, Object>> collect = mapList.stream() + .filter(b -> maps.stream() + .noneMatch(a -> a.get("proName").equals(b.get("proName")))) // 杩囨护鎺夊湪 maps 涓瓨鍦ㄧ殑鐩稿悓鍏冪礌 + .collect(Collectors.toList()); if(!collect.isEmpty()){ - mapList.addAll(collect); -// return AjaxResult.success(result); + maps.addAll(collect); + } + if(!maps.isEmpty()){ + List<Map<String, Object>> collect1 = maps.stream() + .sorted((map1, map2) -> map2.get("proName").toString().compareTo(map1.get("proName").toString())) + .collect(Collectors.toList()); + return AjaxResult.success(collect1); } return AjaxResult.success(maps); }else { diff --git a/ltkj-common/src/main/java/com/ltkj/common/enums/DataSourceType.java b/ltkj-common/src/main/java/com/ltkj/common/enums/DataSourceType.java index 693da70..178fd63 100644 --- a/ltkj-common/src/main/java/com/ltkj/common/enums/DataSourceType.java +++ b/ltkj-common/src/main/java/com/ltkj/common/enums/DataSourceType.java @@ -21,4 +21,6 @@ SLAVE_LIS, + + SLAVE_WS, } diff --git a/ltkj-framework/src/main/java/com/ltkj/framework/config/DruidConfig.java b/ltkj-framework/src/main/java/com/ltkj/framework/config/DruidConfig.java index 8b6b86f..796a281 100644 --- a/ltkj-framework/src/main/java/com/ltkj/framework/config/DruidConfig.java +++ b/ltkj-framework/src/main/java/com/ltkj/framework/config/DruidConfig.java @@ -259,13 +259,61 @@ } + @Bean +// @ConfigurationProperties("spring.datasource.druid.slavepacs") +// @ConditionalOnProperty(prefix = "spring.datasource.druid.slavepacs", name = "enabled", havingValue = "true") + public DataSource slaveDataWsSource(DruidProperties druidProperties) { + DruidDataSource dataSource = DruidDataSourceBuilder.create().build(); + Properties props = new Properties(); + try { + // 浠庢枃浠朵腑璇诲彇閰嶇疆淇℃伅 + FileInputStream fis = null; + try { + fis = new FileInputStream(url); + } catch (FileNotFoundException e) { + log.info("鏁版嵁搴撹繛鎺ユ枃浠舵壘涓嶅埌"); + } + props.load(fis); + fis.close(); + // 杩欓噷鏄祴璇曞啓娉曪紝鍏蜂綋鐨剉alue鍙互閫氳繃璇锋眰鍙傛暟浼犻�掕繃鏉� + String pacsenabled = props.getProperty("pacsenabled"); + if (pacsenabled.equals("false")) + return null; + String pacsdbtype = props.getProperty("wsdbtype"); + switch (pacsdbtype){ + case "sqlserver": + dataSource = creatSqlServer(pacsenabled, props.getProperty("wsip"),props.getProperty("wsprot"), + props.getProperty("wsname"),props.getProperty("wsusername"),props.getProperty("wspassword")); + break; + case "mysql": + dataSource = creatMysql(pacsenabled, props.getProperty("wsip"), + props.getProperty("wsprot"),props.getProperty("wsname"),props.getProperty("wsusername"),props.getProperty("wspassword")); + break; + case "oracle": + dataSource = creatOracle(pacsenabled, props.getProperty("wsip"), + props.getProperty("wsprot"),props.getProperty("wsname"),props.getProperty("wsusername"),props.getProperty("wspassword")); + break; + default: + dataSource = creatOracle(pacsenabled, props.getProperty("wsip"),props.getProperty("wsprot"),props.getProperty("wsname"),props.getProperty("wsusername") + ,props.getProperty("wspassword")); + break; + } + log.info("鏁版嵁搴撹繛鎺ユ垚鍔�!!!"); + } catch (Exception e) { + log.info("鏁版嵁搴撹繛鎺ュけ璐� 璇疯仈绯荤鐞嗗憳锛�"); + e.printStackTrace(); + } + return druidProperties.dataSource(dataSource); + } + + private DruidDataSource creatSqlServer(String enabled, String ip,String port,String db,String user,String password) throws SQLException { DruidDataSource dataSource = DruidDataSourceBuilder.create().build(); Properties properties = new Properties(); properties.setProperty("druid.enabled", enabled); properties.setProperty("druid.driverClassName","com.microsoft.sqlserver.jdbc.SQLServerDriver"); properties.setProperty("druid.url","jdbc:sqlserver://"+ ip+":"+ port+";DatabaseName="+ db+ - ";&characterEncoding=utf8"); + ";encrypt=true;trustServerCertificate=true;sslProtocol=TLSv1.2;"); properties.setProperty("druid.username", user); properties.setProperty("druid.password", password); dataSource.restart(properties); @@ -305,6 +353,7 @@ setDataSource(targetDataSources, DataSourceType.SLAVE_HIS.name(), "slaveHisDataSource"); setDataSource(targetDataSources, DataSourceType.SLAVE_LIS.name(), "slaveDataLisSource"); setDataSource(targetDataSources, DataSourceType.SLAVE_PACS.name(), "slaveDataPacsSource"); + setDataSource(targetDataSources, DataSourceType.SLAVE_WS.name(), "slaveDataWsSource"); return new DynamicDataSource(masterDataSource, targetDataSources); } diff --git a/ltkj-hosp/src/main/java/com/ltkj/hosp/domain/TjOrderDetail.java b/ltkj-hosp/src/main/java/com/ltkj/hosp/domain/TjOrderDetail.java index 967579d..aa08c6e 100644 --- a/ltkj-hosp/src/main/java/com/ltkj/hosp/domain/TjOrderDetail.java +++ b/ltkj-hosp/src/main/java/com/ltkj/hosp/domain/TjOrderDetail.java @@ -239,6 +239,9 @@ @TableField(exist = false) private String ks; + @TableField(exist = false) + private String orgType; + @Override public String toString() { return new ToStringBuilder(this, ToStringStyle.MULTI_LINE_STYLE) diff --git a/ltkj-hosp/src/main/java/com/ltkj/hosp/domain/TjOrderRemark.java b/ltkj-hosp/src/main/java/com/ltkj/hosp/domain/TjOrderRemark.java index 4b73cf1..ef71ad5 100644 --- a/ltkj-hosp/src/main/java/com/ltkj/hosp/domain/TjOrderRemark.java +++ b/ltkj-hosp/src/main/java/com/ltkj/hosp/domain/TjOrderRemark.java @@ -145,6 +145,9 @@ // 绉戝 private String ks; + @TableField(exist = false) + private String orgType; + @Override public String toString() { diff --git a/ltkj-hosp/src/main/java/com/ltkj/hosp/mapper/TestMapper.java b/ltkj-hosp/src/main/java/com/ltkj/hosp/mapper/TestMapper.java index 7721309..985986f 100644 --- a/ltkj-hosp/src/main/java/com/ltkj/hosp/mapper/TestMapper.java +++ b/ltkj-hosp/src/main/java/com/ltkj/hosp/mapper/TestMapper.java @@ -279,6 +279,9 @@ List<LtkjHysqd> getCcXZxYyLtkjHysqdByLisVi(String tjNum); + + + @DataSource(value = DataSourceType.SLAVE_LIS) @Select("SELECT\n" + " a.SAMPLEID tmh,\n" + @@ -305,6 +308,39 @@ List<LtkjHybgd> getCcXZxYyLtkjHybgdByLisVi(String tmh); +// @DataSource(value = DataSourceType.SLAVE_WS) + @Select("SELECT aa.tjh,ws.pro_id tmh,aa.bbbh,aa.bbmc,ws.pro_id xmid,aa.xmmc,aa.sqsj,aa.sqys,aa.jgsj,aa.sqdh,aa.sqrxm,aa.sqrdm,aa.jybgjg,aa.create_time FROM tj_wsxm ws LEFT JOIN (\n" + + " SELECT\n" + + " a.brid tjh,\n" + + " a.brid tmh,\n" + + " NULL bbbh,\n" + + " NULL bbmc,\n" + + " a.xmmc xmid,\n" + + " REGEXP_REPLACE(a.xmmc, '[0-9]', '') xmmc,\n" + + " a.bgsj sqsj,\n" + + " a.bgys sqys,\n" + + " a.bgsj jgsj,\n" + + " null sqdh,\n" + + " null sqrxm,\n" + + " '8001' sqrdm,\n" + + " a.bgys shrxm,\n" + + " '宸插' jybgjg,\n" + + " SYSDATE() create_time \n" + + " FROM\n" + + " aws a \n" + + " WHERE a.brid=#{tjNum} GROUP BY REGEXP_REPLACE(a.xmmc, '[0-9]', '') )aa ON ws.pro_name=aa.xmmc WHERE LOCATE(ws.pro_name,aa.xmmc);") + List<LtkjHysqd> getWsxmLtkjHysqdByLisVi(String tjNum); + +// @DataSource(value = DataSourceType.SLAVE_WS) + @Select("SELECT ws.pro_id tmh,aa.jcxmid,aa.jcxm,NULL tdh,aa.jyjg,null jgdw,null fwzdz,null fwzgz,aa.jysj,aa.shsj,NULL shys,aa.shysmc,NULL tpurl,NULL ycbz,aa.create_time\n" + + " FROM tj_wsxm ws \n" + + " LEFT JOIN (\n" + + " SELECT distinct a.brid tmh,a.xmbm jcxmid,a.xmmc jcxm,NULL tdh,a.result jyjg,null jgdw,null fwzdz,null fwzgz,null fwz,a.bgsj jysj,a.bgys jyys,a.bgsj shsj," + + " NULL shys,a.bgys shysmc, NULL tpurl,NULL ycbz,SYSDATE() create_time FROM aws a WHERE a.brid =#{tmh} )aa \n" + + "\t\tON ws.pro_name=REGEXP_REPLACE(aa.jcxm, '[0-9]', '') WHERE LOCATE(ws.pro_name,REGEXP_REPLACE(aa.jcxm, '[0-9]', ''))") + List<LtkjHybgd> getWsxmLtkjHybgdByLisVi(String tmh); + + @DataSource(value = DataSourceType.SLAVE_PACS) @Select("SELECT * FROM ris.V_TJ_JCBGXX_NEWTJ") -- Gitblit v1.8.0