feat:init and 英德中医院lis任务同步与修复

master
wyb 6 months ago
commit acacab53df

35
.gitignore vendored

@ -0,0 +1,35 @@
target/
!.mvn/wrapper/maven-wrapper.jar
### STS ###
.apt_generated
.classpath
.factorypath
.project
.settings
.springBeans
.sts4-cache
docus-services/docus-services-system1/
### IntelliJ IDEA ###
*.log
.idea
*.iws
*.iml
*.ipr
mvnw*
*.cmd
*.mvn
### NetBeans ###
/nbproject/private/
/nbbuild/
/dist/
/nbdist/
/.nb-gradle/
build/
!**/src/main/**/build/
!**/src/test/**/build/
### VS Code ###
.vscode/
logs*

@ -0,0 +1,73 @@
<assembly xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/assembly-1.0.0.xsd">
<id>exe</id>
<formats>
<format>dir</format>
</formats>
<includeBaseDirectory>false</includeBaseDirectory>
<fileSets>
<fileSet>
<outputDirectory>/lib</outputDirectory>
<directory>${basedir}/target/lib</directory>
</fileSet>
<fileSet>
<outputDirectory>/config</outputDirectory>
<directory>${basedir}/target/resources</directory>
<fileMode>0755</fileMode>
<includes>
<include>*.xml</include>
<include>*.yml</include>
<include>*.properties</include>
</includes>
</fileSet>
<fileSet>
<outputDirectory>/dataConfig</outputDirectory>
<directory>${basedir}/target/dataConfig</directory>
<fileMode>0755</fileMode>
<includes>
<include>*.json</include>
</includes>
</fileSet>
<fileSet>
<outputDirectory>/</outputDirectory>
<directory>${basedir}/target/resources/bin</directory>
<fileMode>0755</fileMode>
<includes>
<include>*.bat</include>
</includes>
</fileSet>
<fileSet>
<outputDirectory>/</outputDirectory>
<directory>${basedir}/target/resources/bin</directory>
<fileMode>0755</fileMode>
<includes>
<include>*.xml</include>
</includes>
</fileSet>
<fileSet>
<outputDirectory>/</outputDirectory>
<directory>${basedir}</directory>
<fileMode>0755</fileMode>
<includes>
<include>*.exe</include>
</includes>
</fileSet>
<!-- 将项目启动jar打包到boot目录中 -->
<fileSet>
<directory>${basedir}/target</directory>
<outputDirectory>/</outputDirectory>
<fileMode>0755</fileMode>
<includes>
<include>${project.build.finalName}.jar</include>
</includes>
</fileSet>
</fileSets>
</assembly>

@ -0,0 +1,360 @@
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<parent>
<groupId>com.docus</groupId>
<artifactId>docus-bom</artifactId>
<version>1.0-SNAPSHOT</version>
</parent>
<modelVersion>4.0.0</modelVersion>
<artifactId>docus-task-ydzyy</artifactId>
<dependencies>
<dependency>
<groupId>com.docus</groupId>
<artifactId>docus-knife4j-starter</artifactId>
</dependency>
<dependency>
<groupId>org.apache.cxf</groupId>
<artifactId>cxf-spring-boot-starter-jaxws</artifactId>
<version>3.3.4</version>
</dependency>
<dependency>
<groupId>org.dom4j</groupId>
<artifactId>dom4j</artifactId>
<version>2.1.1</version>
</dependency>
<!--配置中心客户端-->
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
<exclusions>
<exclusion>
<artifactId>checker-qual</artifactId>
<groupId>org.checkerframework</groupId>
</exclusion>
<exclusion>
<artifactId>error_prone_annotations</artifactId>
<groupId>com.google.errorprone</groupId>
</exclusion>
</exclusions>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<!--mybatis plus-->
<dependency>
<groupId>com.baomidou</groupId>
<artifactId>mybatis-plus-boot-starter</artifactId>
<version>3.4.0</version>
</dependency>
<dependency>
<groupId>com.baomidou</groupId>
<artifactId>dynamic-datasource-spring-boot-starter</artifactId>
<version>3.4.0</version>
</dependency>
<!--nacos-->
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
<exclusions>
<exclusion>
<artifactId>HdrHistogram</artifactId>
<groupId>org.hdrhistogram</groupId>
</exclusion>
<exclusion>
<artifactId>jsr305</artifactId>
<groupId>com.google.code.findbugs</groupId>
</exclusion>
</exclusions>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>8.0.28</version>
</dependency>
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<version>1.18.16</version>
<scope>compile</scope>
</dependency>
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<version>1.18.16</version>
<scope>compile</scope>
</dependency>
<dependency>
<groupId>org.bgee.log4jdbc-log4j2</groupId>
<artifactId>log4jdbc-log4j2-jdbc4.1</artifactId>
</dependency>
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>druid</artifactId>
<version>1.2.4</version>
<scope>compile</scope>
</dependency>
<dependency>
<groupId>com.baomidou</groupId>
<artifactId>mybatis-plus-generator</artifactId>
<version>3.4.1</version>
<scope>compile</scope>
</dependency>
<dependency>
<groupId>org.apache.velocity</groupId>
<artifactId>velocity-engine-core</artifactId>
<version>2.0</version>
</dependency>
<dependency>
<groupId>com.xuxueli</groupId>
<artifactId>xxl-job-core</artifactId>
</dependency>
<dependency>
<groupId>com.docus</groupId>
<artifactId>docus-base-starter</artifactId>
<exclusions>
<exclusion>
<artifactId>knife4j-spring-boot-autoconfigure</artifactId>
<groupId>com.github.xiaoymin</groupId>
</exclusion>
</exclusions>
</dependency>
<dependency>
<groupId>com.docus</groupId>
<artifactId>docus-tool-starter</artifactId>
</dependency>
<dependency>
<groupId>com.docus</groupId>
<artifactId>docus-shiro-starter</artifactId>
</dependency>
<dependency>
<groupId>com.docus</groupId>
<artifactId>docus-base-starter</artifactId>
<exclusions>
<exclusion>
<artifactId>springfox-core</artifactId>
<groupId>io.springfox</groupId>
</exclusion>
<exclusion>
<artifactId>springfox-schema</artifactId>
<groupId>io.springfox</groupId>
</exclusion>
<exclusion>
<artifactId>springfox-spi</artifactId>
<groupId>io.springfox</groupId>
</exclusion>
<exclusion>
<artifactId>knife4j-spring-boot-autoconfigure</artifactId>
<groupId>com.github.xiaoymin</groupId>
</exclusion>
</exclusions>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-hystrix</artifactId>
</dependency>
<!--&lt;!&ndash;添加feign依赖&ndash;&gt;-->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-openfeign</artifactId>
</dependency>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<scope>test</scope>
</dependency>
<!--sqlserver驱动-->
<dependency>
<groupId>com.microsoft.sqlserver</groupId>
<artifactId>sqljdbc4</artifactId>
<version>4.0</version>
</dependency>
<!-- oracle -->
<dependency>
<groupId>com.oracle</groupId>
<artifactId>ojdbc6</artifactId>
<version>11.2.0.4.0</version>
</dependency>
</dependencies>
<build>
<resources>
<resource>
<directory>src/main/resources</directory>
<filtering>true</filtering>
</resource>
</resources>
<plugins>
<plugin>
<!--打包时去除第三方依赖-->
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<version>2.4.4</version>
<configuration>
<layout>ZIP</layout>
<includes>
<include>
<groupId>non-exists</groupId>
<artifactId>non-exists</artifactId>
</include>
</includes>
</configuration>
<executions>
<execution>
<goals>
<goal>repackage</goal>
</goals>
</execution>
</executions>
</plugin>
<!--拷贝第三方依赖文件到指定目录-->
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-dependency-plugin</artifactId>
<executions>
<execution>
<id>copy-dependencies</id>
<phase>package</phase>
<goals>
<goal>copy-dependencies</goal>
</goals>
<configuration>
<!--target/lib是依赖jar包的输出目录根据自己喜好配置-->
<outputDirectory>target/lib</outputDirectory>
<excludeTransitive>false</excludeTransitive>
<stripVersion>false</stripVersion>
<includeScope>runtime</includeScope>
</configuration>
</execution>
</executions>
</plugin>
<!-- copy资源文件 -->
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-resources-plugin</artifactId>
<version>3.2.0</version>
<executions>
<execution>
<id>copy-resources</id>
<phase>package</phase>
<goals>
<goal>copy-resources</goal>
</goals>
<configuration>
<resources>
<resource>
<directory>src/main/resources</directory>
<includes>
<include>**/*.*</include>
</includes>
</resource>
</resources>
<outputDirectory>${project.build.directory}/resources</outputDirectory>
</configuration>
</execution>
<execution>
<id>copy-bin</id>
<phase>package</phase>
<goals>
<goal>copy-resources</goal>
</goals>
<configuration>
<resources>
<resource>
<directory>src/main/resources</directory>
<filtering>true</filtering>
<includes>
<include>bin/*.xml</include>
<include>*.yml</include>
<include>bin/*.bat</include>
</includes>
</resource>
</resources>
<outputDirectory>${project.build.directory}/resources</outputDirectory>
</configuration>
</execution>
<execution>
<id>copy-data-config</id>
<phase>package</phase>
<goals>
<goal>copy-resources</goal>
</goals>
<configuration>
<resources>
<resource>
<directory>../../dataConfig</directory>
<filtering>true</filtering>
</resource>
</resources>
<outputDirectory>${project.build.directory}/dataConfig</outputDirectory>
</configuration>
</execution>
</executions>
</plugin>
<!-- 打jar包时忽略配置文件 -->
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-jar-plugin</artifactId>
<version>3.2.0</version>
<configuration>
<excludes>
<exclude>**/*.yml</exclude>
</excludes>
</configuration>
</plugin>
<plugin>
<artifactId>maven-assembly-plugin</artifactId>
<executions>
<execution>
<configuration>
<finalName>${project.artifactId}</finalName>
<appendAssemblyId>false</appendAssemblyId>
<descriptors>
<descriptor>assembly.xml</descriptor>
</descriptors>
</configuration>
<id>make-assembly</id>
<phase>package</phase>
<goals>
<goal>single</goal>
</goals>
</execution>
</executions>
</plugin>
</plugins>
</build>
<profiles>
<profile>
<id>dev</id>
<properties>
<profile.name>prod</profile.name>
</properties>
<activation>
<activeByDefault>true</activeByDefault>
</activation>
</profile>
</profiles>
</project>

@ -0,0 +1,28 @@
package com.docus.server;
import lombok.extern.slf4j.Slf4j;
import org.mybatis.spring.annotation.MapperScan;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.openfeign.EnableFeignClients;
import org.springframework.scheduling.annotation.EnableAsync;
import java.util.Properties;
@Slf4j
@SpringBootApplication(scanBasePackages = {"com.docus"})
@MapperScan("com.docus.server.**.mapper")
@EnableFeignClients(basePackages = {"com.docus"})
@EnableAsync
public class AppRunBootstrap {
public static void main(String[] args) {
Properties props = System.getProperties();
props.setProperty("org.apache.cxf.stax.allowInsecureParser", "1");
props.setProperty("UseSunHttpHandler", "true");
System.setProperty("javax.xml.parsers.DocumentBuilderFactory", "com.sun.org.apache.xerces.internal.jaxp.DocumentBuilderFactoryImpl");
SpringApplication.run(AppRunBootstrap.class, args);
}
}

@ -0,0 +1,69 @@
package com.docus.server;
import com.xxl.job.core.executor.impl.XxlJobSpringExecutor;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
/**
* @ProjectName:
* @Description:
* @Param
* @Return
* @Author:
* @CreateDate: 2021/5/7 16:23
* @UpdateUser:
* @UpdateDate: 2021/5/7 16:23
* @UpdateRemark:
* @Version: 1.0
*/
@Configuration
public class XxlJobConfig {
private Logger logger = LoggerFactory.getLogger(XxlJobConfig.class);
@Value("${xxl.job.admin.addresses}")
private String adminAddresses;
@Value("${xxl.job.accessToken}")
private String accessToken;
@Value("${xxl.job.executor.appname}")
private String appname;
@Value("${xxl.job.executor.address}")
private String address;
@Value("${xxl.job.executor.ip}")
private String ip;
@Value("${xxl.job.executor.port}")
private int port;
@Value("${xxl.job.executor.logpath}")
private String logPath;
@Value("${xxl.job.executor.logretentiondays}")
private int logRetentionDays;
@Bean
public XxlJobSpringExecutor xxlJobExecutor() {
logger.info(">>>>>>>>>>> xxl-job config init.");
XxlJobSpringExecutor xxlJobSpringExecutor = new XxlJobSpringExecutor();
xxlJobSpringExecutor.setAdminAddresses(adminAddresses);
xxlJobSpringExecutor.setAppname(appname);
xxlJobSpringExecutor.setAddress(address);
xxlJobSpringExecutor.setIp(ip);
xxlJobSpringExecutor.setPort(port);
xxlJobSpringExecutor.setAccessToken(accessToken);
xxlJobSpringExecutor.setLogPath(logPath);
xxlJobSpringExecutor.setLogRetentionDays(logRetentionDays);
return xxlJobSpringExecutor;
}
}

@ -0,0 +1,102 @@
package com.docus.server.archive.entity;
import io.swagger.annotations.ApiModelProperty;
import lombok.Data;
import java.io.Serializable;
import java.util.Date;
@Data
public class AfCollectTask implements Serializable {
@ApiModelProperty(value = "id 雪花算法")
private Long id;
@ApiModelProperty(value = "病案主键")
private String patientId;
@ApiModelProperty(value = "af_archive_detail表id")
private Long afArchiveDetailId;
@ApiModelProperty(value = "来源 1护理文书2 HIS电子病历3 Pacs检查4心电系统5手麻系统6 Lis检验7临床首页8长期医嘱 9临时医嘱10 省病案统计系统首页11 扫描首页;")
private String sysflag;
@ApiModelProperty(value = "开始时间")
private Date startTime;
@ApiModelProperty(value = "结束时间")
private Date endTime;
@ApiModelProperty(value = "任务状态 0未开始1:正在采集2采集错误3采集完成")
private String state;
@ApiModelProperty(value = "同步时间")
private Date syncTime;
@ApiModelProperty(value = "最新重新采集时间")
private Date recollectTime;
@ApiModelProperty(value = "最新重新采集人")
private String recollectName;
@ApiModelProperty(value = "备注")
private String remark;
@ApiModelProperty(value = "presult")
private String presult;
@ApiModelProperty(value = "报告唯一单号")
private String c1;
@ApiModelProperty(value = "文件名称")
private String c2;
@ApiModelProperty(value = "记账号")
private String c3;
@ApiModelProperty(value = "c4")
private String c4;
@ApiModelProperty(value = "c5")
private String c5;
@ApiModelProperty(value = "c6,英德中医院的fileTitle")
private String c6;
@ApiModelProperty(value = "c7")
private String c7;
@ApiModelProperty(value = "c8")
private String c8;
@ApiModelProperty(value = "c9")
private String c9;
@ApiModelProperty(value = "c10 用作采集器完成任务时的采集器key")
private String c10;
@ApiModelProperty(value = "c9")
private Date t1;
@ApiModelProperty(value = "c9")
private Date t2;
@ApiModelProperty(value = "任务耗时")
private Long consumingTime;
@ApiModelProperty(value = "任务创建时间")
private Date createTime;
}

@ -0,0 +1,162 @@
package com.docus.server.archive.entity;
import io.swagger.annotations.ApiModel;
import io.swagger.annotations.ApiModelProperty;
import lombok.Data;
import lombok.EqualsAndHashCode;
import java.io.Serializable;
import java.util.Date;
/**
* <p>
*
* </p>
*
* @author jiashi
* @since 2021-04-14
*/
@Data
@EqualsAndHashCode(callSuper = false)
@ApiModel(value = "TBasic对象", description = "病案基本信息")
public class TBasic implements Serializable {
private static final long serialVersionUID = 1L;
@ApiModelProperty(value = "病案主键")
private String patientId;
@ApiModelProperty(value = "住院次数")
private Integer admissTimes;
@ApiModelProperty(value = "病案号")
private String inpatientNo;
@ApiModelProperty(value = "住院ID号")
private String admissId;
@ApiModelProperty(value = "患者姓名")
private String name;
@ApiModelProperty(value = "盘号")
private String ph;
@ApiModelProperty(value = "性别")
private String sex;
@ApiModelProperty(value = "年龄_岁")
private Integer age;
@ApiModelProperty(value = "年龄_月")
private Integer ageMonth;
@ApiModelProperty(value = "年龄_天")
private Integer ageDay;
@ApiModelProperty(value = "身份证")
private String idCard;
@ApiModelProperty(value = "手机号码")
private String telphone;
@ApiModelProperty(value = "住院日期")
private Date admissDate;
@ApiModelProperty(value = "住院科室")
private String admissDept;
@ApiModelProperty(value = "住院科室名称")
private String admissDeptName;
@ApiModelProperty(value = "出院日期")
private Date disDate;
@ApiModelProperty(value = "出院科室")
private String disDept;
@ApiModelProperty(value = "出院科室名称")
private String disDeptName;
@ApiModelProperty(value = "实际住院天数")
private Integer admissDays;
@ApiModelProperty(value = "主管医生")
private String attending;
@ApiModelProperty(value = "主管医生名称")
private String attendingName;
@ApiModelProperty(value = "主要诊断编码")
private String mainDiagCode;
@ApiModelProperty(value = "主要诊断名称")
private String mainDiagName;
@ApiModelProperty(value = "主要手术编码")
private String mainOperateCode;
@ApiModelProperty(value = "主要手术名称")
private String mainOperateName;
@ApiModelProperty(value = "是否死亡")
private Integer isDead;
@ApiModelProperty(value = "是否作废(01是)")
private Integer isCancel;
@ApiModelProperty(value = "创建时间")
private Date createTime;
@ApiModelProperty(value = "修改时间")
private Date updateTime;
@ApiModelProperty(value = "是否归档 1已归档0未归档")
private Integer isArchive;
@ApiModelProperty(value = "归档时间")
private Date archiveTime;
@ApiModelProperty(value = "文件来源 1:af_archive_detail,2:t_scan_assort")
private Integer fileSource;
@ApiModelProperty(value = "完整性描述")
private String integrityDesc;
private String bColumn1;
private String bColumn2;
private String bColumn3;
private String bColumn4;
private String bColumn5;
private Integer bColumn6;
private Integer bColumn7;
private Integer bColumn8;
private Integer bColumn9;
private Integer bColumn10;
@ApiModelProperty(value = "姓名缩写(内部构成)")
private String nameSpell;
@ApiModelProperty(value = "性别名称")
private String sexName;
@ApiModelProperty(value = "记账号")
private String jzh;
@ApiModelProperty(value = "外部id")
private String externalId;
@ApiModelProperty(value = "档案文件存储类型1pdf默认2图片")
private Integer archiveFileStorageType;
@ApiModelProperty(value = "是否标记编码 0否1是")
private Integer isCoder;
}

@ -0,0 +1,24 @@
package com.docus.server.archive.enums;
import lombok.Getter;
/**
* @author YongBin Wen
* @date 2025/1/16 14:38
*/
@Getter
public enum SysFlagType {
/**
*
*/
LIS("6");
/**
*
*/
private final String type;
SysFlagType(String type) {
this.type = type;
}
}

@ -0,0 +1,26 @@
package com.docus.server.archive.mapper;
import com.baomidou.dynamic.datasource.annotation.DS;
import com.docus.server.archive.entity.AfCollectTask;
import org.apache.ibatis.annotations.Param;
import java.util.List;
/**
* mapper
*
* @author wyb
*/
@DS("archive-mysql")
public interface AfCollectTaskMapper {
int saveBatch(@Param("tasks") List<AfCollectTask> collectTasks);
int update(@Param("tasks") List<AfCollectTask> collectTasks);
List<AfCollectTask> findByPatientIds(@Param("patientIdList") List<String> patientIdList);
int cancelTask(@Param("taskIds") List<Long> taskIds);
int cancelFile(@Param("taskIds") List<Long> taskIds);
}

@ -0,0 +1,20 @@
package com.docus.server.archive.mapper;
import com.baomidou.dynamic.datasource.annotation.DS;
import com.docus.server.archive.entity.TBasic;
import org.apache.ibatis.annotations.Param;
import java.util.List;
/**
* mapper
*
* @author wyb
*/
@DS("archive-mysql")
public interface TBasicMapper {
List<TBasic> getByDisDate(@Param("start") String start,@Param("end") String end);
List<TBasic> getByPatientIds(@Param("patientIdList") List<String> patientIdList);
}

@ -0,0 +1,61 @@
package com.docus.server.synclis.controller;
import com.docus.core.util.Func;
import com.docus.infrastructure.web.api.CommonResult;
import com.docus.server.archive.entity.TBasic;
import com.docus.server.archive.mapper.TBasicMapper;
import com.docus.server.synclis.service.LisService;
import io.swagger.annotations.Api;
import io.swagger.annotations.ApiOperation;
import lombok.extern.slf4j.Slf4j;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import javax.annotation.Resource;
import java.util.Date;
import java.util.List;
/**
* @author YongBin Wen
* @date 2025/1/16 17:10
*/
@RestController
@Api(tags = "LIS检验报告视图任务")
@RequestMapping("/ydzyylistask")
@Slf4j
public class LisTaskController {
@Resource
private LisService lisService;
@Resource
private TBasicMapper basicMapper;
@ApiOperation(value = "根据患者主键,同步")
@GetMapping("/syncFullLisByPatientIds")
public CommonResult<String> syncFullLisByPatientIds(@RequestBody List<String> patientIds){
if(Func.isEmpty(patientIds)){
return CommonResult.failed("请传入正确的患者病案主键!");
}
List<TBasic> basicList = basicMapper.getByPatientIds(patientIds);
for (TBasic basic : basicList) {
lisService.syncFullTask(basic);
}
return CommonResult.success("同步完成!");
}
@ApiOperation(value = "修订门诊任务和文件")
@GetMapping("/revisionMzTaskAndFile")
public CommonResult<String> revisionMzTaskAndFile() {
String start = "2022-10-01 00:00:00";
String end = Func.formatDateTime(new Date());
List<TBasic> tbasics = basicMapper.getByDisDate(start, end);
log.info(">>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> 修订门诊任务和文件。出院时间:{} 至 {} 共 {} 条数据!", start, end, tbasics.size());
for (TBasic tbasic : tbasics) {
lisService.revisionMzTaskAndFile(tbasic);
}
return CommonResult.success("修订完成!");
}
}

@ -0,0 +1,40 @@
package com.docus.server.synclis.converter;
import com.docus.core.util.Func;
import com.docus.server.archive.entity.AfCollectTask;
import com.docus.server.archive.entity.TBasic;
import com.docus.server.archive.enums.SysFlagType;
import com.docus.server.synclis.entity.LisView;
import java.util.Date;
/**
* @author YongBin Wen
* @date 2025/1/16 14:33
*/
public class LisViewConverter {
public static AfCollectTask convertTask(LisView view, TBasic basic) {
if (view == null) {
return null;
}
AfCollectTask task = new AfCollectTask();
task.setPatientId(basic.getPatientId());
task.setSysflag(SysFlagType.LIS.getType());
task.setSyncTime(new Date());
task.setState("0");
task.setPresult("");
task.setC1(view.getPatientId());
task.setC2(view.getLabNum());
task.setC3(view.getName());
task.setC4(view.getLabNum());
task.setC5(basic.getJzh());
task.setC6(view.getCheckName());
task.setC7(view.getPatSource());
String pattern1 = "yyyy-MM-dd";
String pattern2 = "yyyy-MM-dd HH:mm:ss";
task.setT1(pattern1.length() == view.getReqDate().length() ? Func.parseDate(view.getAuditTime(), pattern1) : Func.parseDate(view.getAuditTime(), pattern2));
task.setT2(Func.parseDate(view.getAuditTime(), pattern2));
return task;
}
}

@ -0,0 +1,52 @@
package com.docus.server.synclis.entity;
import lombok.Data;
/**
* @author YongBin Wen
* @date 2025/1/16 11:05
*/
@Data
public class LisView {
/**
* lisid
*/
private String patientId;
/**
*
*/
private String labNum;
/**
*
*/
private String name;
/**
*
*/
private String hstNum;
/**
*
*/
private String reqNum;
/**
* yyyy-MM-dd yyyy-MM-dd HH:mm:ss
*/
private String reqDate;
/**
*
*/
private String auditTime;
/**
*
*/
private String checkName;
/**
*
*/
private String patSource;
/**
*
*/
private String idCard;
}

@ -0,0 +1,43 @@
package com.docus.server.synclis.job;
import com.docus.core.util.Func;
import com.docus.server.archive.entity.TBasic;
import com.docus.server.archive.mapper.TBasicMapper;
import com.docus.server.synclis.service.LisService;
import com.xxl.job.core.handler.annotation.XxlJob;
import lombok.extern.slf4j.Slf4j;
import org.springframework.stereotype.Component;
import javax.annotation.Resource;
import java.util.Date;
import java.util.List;
/**
* @author YongBin Wen
* @date 2025/1/16 16:44
*/
@Slf4j
@Component
public class LisTaskSyncJob {
@Resource
private LisService lisService;
@Resource
private TBasicMapper tBasicMapper;
@XxlJob("lisTaskSyncJob")
private void lisTaskSyncJob() {
String start = "2022-10-01 00:00:00";
String end = Func.formatDateTime(new Date());
try {
List<TBasic> tbasics = tBasicMapper.getByDisDate(start, end);
log.info(">>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> LIS视图任务同步开始。出院时间{} 至 {} 共 {} 条数据!", start, end, tbasics.size());
for (TBasic tbasic : tbasics) {
lisService.syncViewTask(tbasic);
}
log.info(">>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> LIS视图任务结束同步。");
} catch (Exception ex) {
log.error(">>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> LIS视图任务同步出错了" + ex.getMessage(), ex);
}
}
}

@ -0,0 +1,68 @@
package com.docus.server.synclis.mapper;
import com.baomidou.dynamic.datasource.annotation.DS;
import com.docus.server.synclis.entity.LisView;
import org.apache.ibatis.annotations.Param;
import java.util.List;
/**
* v_LISReport_YDZYView a.crt_time >= CONVERT(DATETIME,DATEADD(MONTH,-3,GETDATE()))
* getFullZyData() getFullMzData()
* <p>
* SELECT a.patient_id,a.lab_num,b.name,a.hst_num,ISNULL(a.req_num,'') AS req_num,
* a.req_date,CONVERT(VARCHAR(19),a.audit_time,120) AS audit_time,
* dbo.fnGetChkTypeNameByLabNum(a.lab_num) AS CheckName,ISNULL(c.name,'') AS PatSource,
* ISNULL(b.id_card,'') as IDCARD
* FROM hylisdb..patient_register a WITH(NOLOCK)
* JOIN hylisdb..patient_baseinfo b WITH(NOLOCK) ON a.patient_id=b.patient_id
* JOIN hylisdb..ill_type c ON a.send_type=c.type_id
* WHERE a.crt_time >= CONVERT(DATETIME,DATEADD(MONTH,-3,GETDATE()))
* AND a.proc_flag = '8';
*
* @author YongBin Wen
* @date 2025/1/16 11:21
*/
@DS("ydzyy-lis-sqlserver")
public interface LisViewMapper {
/**
* lis
*
* @param inpatientNo
* @param admissDate
* @param disDate
* @return
*/
List<LisView> getZyDataFromView(@Param("inpatientNo") String inpatientNo, @Param("admissDate") String admissDate, @Param("disDate") String disDate);
/**
* lis
*
* @param idCard
* @param startDate
* @param endDate
* @return
*/
List<LisView> getMzDataFromView(@Param("idCard") String idCard, @Param("startDate") String startDate, @Param("endDate") String endDate);
/**
* lis
*
* @param inpatientNo
* @param admissDate
* @param disDate
* @return
*/
List<LisView> getFullZyData(@Param("inpatientNo") String inpatientNo, @Param("admissDate") String admissDate, @Param("disDate") String disDate);
/**
* lis
*
* @param idCard
* @param startDate
* @param endDate
* @return
*/
List<LisView> getFullMzData(@Param("idCard") String idCard, @Param("startDate") String startDate, @Param("endDate") String endDate);
}

@ -0,0 +1,29 @@
package com.docus.server.synclis.service;
import com.docus.server.archive.entity.TBasic;
/**
* @author YongBin Wen
* @date 2025/1/16 15:06
*/
public interface LisService {
/**
*
*
* @param tBasic
*/
void syncViewTask(TBasic tBasic);
/**
*
*
* @param tBasic
*/
void syncFullTask(TBasic tBasic);
/**
*
* @param tbasic
*/
void revisionMzTaskAndFile(TBasic tbasic);
}

@ -0,0 +1,234 @@
package com.docus.server.synclis.service.impl;
import com.docus.core.util.Func;
import com.docus.infrastructure.redis.service.IdService;
import com.docus.server.archive.entity.AfCollectTask;
import com.docus.server.archive.entity.TBasic;
import com.docus.server.archive.enums.SysFlagType;
import com.docus.server.archive.mapper.AfCollectTaskMapper;
import com.docus.server.synclis.converter.LisViewConverter;
import com.docus.server.synclis.entity.LisView;
import com.docus.server.synclis.mapper.LisViewMapper;
import com.docus.server.synclis.service.LisService;
import lombok.extern.slf4j.Slf4j;
import org.springframework.stereotype.Service;
import javax.annotation.Resource;
import java.time.LocalDateTime;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.Collections;
import java.util.Date;
import java.util.List;
import java.util.Objects;
import java.util.concurrent.locks.ReentrantLock;
import java.util.stream.Collectors;
/**
* @author YongBin Wen
* @date 2025/1/16 15:06
*/
@Service
@Slf4j
public class LisServiceImpl implements LisService {
@Resource
private LisViewMapper lisViewMapper;
@Resource
private AfCollectTaskMapper afCollectTaskMapper;
@Resource
private IdService idService;
private final static ReentrantLock SAVE_TASK_LOCK = new ReentrantLock();
@Override
public void syncViewTask(TBasic tBasic) {
syncViewZyTask(tBasic);
syncViewMzTask(tBasic);
}
@Override
public void syncFullTask(TBasic tBasic) {
syncFullZyTask(tBasic);
syncFullMzTask(tBasic);
}
@Override
public void revisionMzTaskAndFile(TBasic tbasic) {
String patientId = tbasic.getPatientId();
List<String> mzSource= Arrays.asList( "门诊","急诊");
Date admissDate = tbasic.getAdmissDate();
String admissDateStr = Func.formatDateTime(admissDate);
LocalDateTime admissLocalDateTime = Func.parseDateTime(admissDateStr);
LocalDateTime startLocalDateTime = admissLocalDateTime.plusDays(-3);
String start = startLocalDateTime.toLocalDate().toString() + " 00:00:00";
Date startDateTime = Func.parseDate(start,"yyyy-MM-dd HH:mm:ss");
List<AfCollectTask> collectTasks = afCollectTaskMapper.findByPatientIds(Collections.singletonList(patientId));
List<AfCollectTask> mzCollectTasks=collectTasks.stream().filter(tsk->
SysFlagType.LIS.getType().equals(tsk.getSysflag()) && mzSource.contains(tsk.getC7())
).collect(Collectors.toList());
if(Func.isEmpty(mzCollectTasks)){
return;
}
List<AfCollectTask> cancelTasks=new ArrayList<>();
for (AfCollectTask mzCollectTask : mzCollectTasks) {
Date reqDate = mzCollectTask.getT1();
// 如果申请时间不在入院前三天范围内,则作废
if(reqDate.after(admissDate) || reqDate.before(startDateTime)){
cancelTasks.add(mzCollectTask);
}
}
if(Func.isEmpty(cancelTasks)){
return;
}
List<Long> cancelTaskIds = cancelTasks.stream().map(AfCollectTask::getId).collect(Collectors.toList());
afCollectTaskMapper.cancelTask(cancelTaskIds);
afCollectTaskMapper.cancelFile(cancelTaskIds);
}
public static void main(String[] args) {
TBasic tBasic = new TBasic();
tBasic.setAdmissDate(new Date());
new LisServiceImpl().revisionMzTaskAndFile(tBasic);
}
/**
*
*/
private void syncViewZyTask(TBasic tBasic) {
String inpatientNo = tBasic.getInpatientNo();
Date admissDate = tBasic.getAdmissDate();
Date disDate = tBasic.getDisDate();
if (Func.isBlank(inpatientNo) || Objects.isNull(admissDate) || Objects.isNull(disDate)) {
log.warn("LIS同步视图住院任务失败病案号、入院日期、出院日期 有空数据!患者主键:{}", tBasic.getPatientId());
return;
}
String admissDateStr = Func.formatDateTime(admissDate);
String disDateStr = Func.formatDateTime(disDate);
List<LisView> zyDataFromView = lisViewMapper.getZyDataFromView(inpatientNo, admissDateStr, disDateStr);
saveTask(zyDataFromView, tBasic);
}
/**
* ,
*/
private void syncViewMzTask(TBasic tBasic) {
String idCard = tBasic.getIdCard();
Date admissDate = tBasic.getAdmissDate();
if (Func.isBlank(idCard) || Objects.isNull(admissDate)) {
log.warn("LIS同步视图门诊任务失败数据身份证号码 或者 入院日期 为空!患者主键:{}", tBasic.getPatientId());
return;
}
String admissDateStr = Func.formatDateTime(admissDate);
LocalDateTime startLocalDateTime = Func.parseDateTime(admissDateStr).plusDays(-3);
String startLocalDateStr = startLocalDateTime.toLocalDate().toString();
List<LisView> mzDataFromView = lisViewMapper.getMzDataFromView(idCard, startLocalDateStr, admissDateStr);
saveTask(mzDataFromView, tBasic);
}
private void syncFullZyTask(TBasic tBasic) {
String inpatientNo = tBasic.getInpatientNo();
Date admissDate = tBasic.getAdmissDate();
Date disDate = tBasic.getDisDate();
if (Func.isBlank(inpatientNo) || Objects.isNull(admissDate) || Objects.isNull(disDate)) {
log.warn("LIS同步完整住院任务失败病案号、入院日期、出院日期 有空数据!患者主键:{}", tBasic.getPatientId());
return;
}
String admissDateStr = Func.formatDateTime(admissDate);
String disDateStr = Func.formatDateTime(disDate);
List<LisView> zyDataFromView = lisViewMapper.getFullZyData(inpatientNo, admissDateStr, disDateStr);
saveTask(zyDataFromView, tBasic);
}
private void syncFullMzTask(TBasic tBasic) {
String idCard = tBasic.getIdCard();
Date admissDate = tBasic.getAdmissDate();
if (Func.isBlank(idCard) || Objects.isNull(admissDate)) {
log.warn("LIS同步完整门诊任务失败数据身份证号码 或者 入院日期 为空!患者主键:{}", tBasic.getPatientId());
return;
}
String admissDateStr = Func.formatDateTime(admissDate);
LocalDateTime startLocalDateTime = Func.parseDateTime(admissDateStr).plusDays(-3);
String startLocalDateStr = startLocalDateTime.toLocalDate().toString();
List<LisView> mzDataFromView = lisViewMapper.getFullMzData(idCard, startLocalDateStr, admissDateStr);
saveTask(mzDataFromView, tBasic);
}
private void saveTask(List<LisView> mzDataFromView, TBasic tBasic) {
if (Func.isEmpty(mzDataFromView)) {
return;
}
SAVE_TASK_LOCK.lock();
try {
List<String> patientIds = Collections.singletonList(tBasic.getPatientId());
List<AfCollectTask> existsTasks = afCollectTaskMapper.findByPatientIds(patientIds);
List<AfCollectTask> existsLisTasks = existsTasks.stream()
.filter(tsk -> SysFlagType.LIS.getType().equals(tsk.getSysflag()))
.collect(Collectors.toList());
List<AfCollectTask> newTaskList = new ArrayList<>();
List<AfCollectTask> updateTaskList = new ArrayList<>();
for (LisView lisView : mzDataFromView) {
AfCollectTask convertTask = LisViewConverter.convertTask(lisView, tBasic);
AfCollectTask existsTask = findExistsTask(existsLisTasks, convertTask);
if (existsTask == null) {
convertTask.setId(idService.getDateSeq());
convertTask.setCreateTime(new Date());
newTaskList.add(convertTask);
continue;
}
// 如果任务还在进行 或者 视图审核时间没有增大,不进行更新
if ("0".equals(existsTask.getState()) || !convertTask.getT2().after(existsTask.getT2())) {
continue;
}
// 更新
existsTask.setT1(convertTask.getT1());
existsTask.setT2(convertTask.getT2());
existsTask.setPresult("");
existsTask.setSyncTime(new Date());
updateTaskList.add(existsTask);
}
if (Func.isNotEmpty(newTaskList)) {
afCollectTaskMapper.saveBatch(newTaskList);
}
if (Func.isNotEmpty(updateTaskList)) {
afCollectTaskMapper.update(updateTaskList);
}
} catch (Exception ex) {
log.error("保存/修改LIS任务出错了" + ex.getMessage(), ex);
} finally {
SAVE_TASK_LOCK.unlock();
}
}
/**
*
*
* @param existsLisTasks
* @param convertTask
* @return
*/
private AfCollectTask findExistsTask(List<AfCollectTask> existsLisTasks, AfCollectTask convertTask) {
for (AfCollectTask existsLisTask : existsLisTasks) {
if (existsLisTask.getC1().equals(convertTask.getC1()) &&
existsLisTask.getC2().equals(convertTask.getC2()) &&
existsLisTask.getPatientId().equals(convertTask.getPatientId()) &&
existsLisTask.getC3().equals(convertTask.getC3()) &&
existsLisTask.getC4().equals(convertTask.getC4())) {
return existsLisTask;
}
}
return null;
}
}

@ -0,0 +1,6 @@
@echo off
WinSW.exe status|findstr NonExistent && winsw install
WinSW.exe status|findstr Stopped && winsw start

@ -0,0 +1,33 @@
@echo off
for /f "delims=" %%t in ('winsw.exe status') do set str=%%t
echo %str%
if %str%==Started (
echo "restart....."
winsw stop
PING 127.0.0.1 -n 10 -w 30000 >NUL
winsw start
)
if %str%==Stopped (
echo "start....."
winsw start
)
if %str%==NonExistent (
echo "deploy and start....."
winsw install
winsw start
echo c
)

@ -0,0 +1,23 @@
@echo off
set parentDir=%1
echo %parentDir%
if ""==%parentDir% set parentDir=d:\webroot
set deployDir=%parentDir%\@project.artifactId@
set curr_file=%cd%
cd /d %deployDir%
call stop.bat
sc query @project.artifactId@ |Find "RUNNING" && ping 127.0.0.1 -n 10 >nul
cd %curr_file%
rd/s/q %deployDir%\lib
rd/s/q %deployDir%\dataConfig
rd/s/q %deployDir%\config
del /s/q %deployDir%\*.jar
xcopy /Y/E/I * %deployDir%
cd /d %deployDir%
call auto.bat
cd %curr_file%

@ -0,0 +1,21 @@
set java_opts=-Xms512m -Xmx512m
set key="java_opts"
rem 文件不存在,就跳过
if not exist java-ops.ini goto end
for /f "tokens=1,2 delims==" %%i in (java-ops.ini) do (
if "%%i"==%key% set java_opts=%%j)
echo java_opts is : %java_opts%
:end
rem 启动java
java %java_opts% -Dfile.encoding=utf-8 -jar -Dspring.profiles.active=@profile.name@ -Dloader.path=config,lib @project.build.finalName@.jar

@ -0,0 +1,13 @@
@echo off
for /f "delims=" %%t in ('winsw.exe status') do set str=%%t
echo %str%
if %str%==Started (
winsw stop
@echo wait program stop .....
PING 127.0.0.1 -n 30 -w 10000 >NUL
)

@ -0,0 +1,19 @@
@echo off
set deployDir=%1\docus-task-ydzyy
if %deployDir%=="" set deployDir=d:\webroot\docus-task-ydzyy
set curr_file=%cd%
cd /d %deployDir%
call stop.bat
cd %curr_file%
sc query docus-backup-sys |Find "RUNNING" && ping 127.0.0.1 -n 10 >nul
rd/s/q %deployDir%\lib
rd/s/q %deployDir%\dataConfig
rd/s/q %deployDir%\config
del /s/q %deployDir%\*.jar
xcopy /Y/E/I * %deployDir%
cd /d %deployDir%
call install.bat

@ -0,0 +1,8 @@
<service>
<id>docus-task-ydzyy</id>
<name>生产-嘉时病案无纸化-英德中医院视图任务同步</name>
<description>生产-嘉时病案无纸化-英德中医院视图任务同步</description>
<startmode>Automatic</startmode>
<executable>%BASE%\start.bat</executable>
<log mode="none"></log>
</service>

@ -0,0 +1,128 @@
server:
port: 9294
spring:
application:
name: @artifactId@
datasource:
dynamic:
primary: archive-mysql
#是否用严格模式,如果启用在味匹配到指定数据源时抛出异常
strict: false
datasource:
# 多数据源
archive-mysql:
url: jdbc:log4jdbc:mysql://db.docus.cn:3306/docus_archivefile?autoReconnect=true&allowMultiQueries=true&useSSL=false&useUnicode=true&characterEncoding=utf-8&serverTimezone=Asia/Shanghai
username: docus
password: docus702
driver-class-name: net.sf.log4jdbc.sql.jdbcapi.DriverSpy
type: com.alibaba.druid.pool.DruidDataSource
# 初始化配置
initial-size: 3
# 最小连接数
min-idle: 3
# 最大连接数
max-active: 15
# 获取连接超 时时间
max-wait: 5000
# 连接有效性检测时间
time-between-eviction-runs-millis: 90000
# 最大空闲时间
min-evictable-idle-time-millis: 1800000
test-while-idle: true
test-on-borrow: false
test-on-return: false
validation-query: select 1
ydzyy-lis-sqlserver:
url: jdbc:sqlserver://199.168.91.211:1433;DatabaseName=GCRIS2
username: wzh
password: Wzh@#2023
driver-class-name: com.microsoft.sqlserver.jdbc.SQLServerDriver
type: com.alibaba.druid.pool.DruidDataSource
# 初始化配置
initial-size: 3
# 最小连接数
min-idle: 3
# 最大连接数
max-active: 15
# 获取连接超 时时间
max-wait: 5000
# 连接有效性检测时间
time-between-eviction-runs-millis: 90000
# 最大空闲时间
min-evictable-idle-time-millis: 1800000
test-while-idle: true
test-on-borrow: false
test-on-return: false
validation-query: select 1
ydzyy-hisdb-oracle:
url: jdbc:oracle:thin:@//10.10.100.02:1521/HISDB
username: WZHPL
password: 123456
driver-class-name: oracle.jdbc.driver.OracleDriver
type: com.alibaba.druid.pool.DruidDataSource
# 初始化配置
initial-size: 3
# 最小连接数
min-idle: 3
# 最大连接数
max-active: 5
# 获取连接超 时时间
max-wait: 5000
# 连接有效性检测时间
time-between-eviction-runs-millis: 90000
# 最大空闲时间
min-evictable-idle-time-millis: 1800000
test-while-idle: true
test-on-borrow: false
test-on-return: false
validation-query: select 1 from dual
redis:
host: redis.docus.cn
password: JSdocus@702
cloud:
nacos:
discovery:
server-addr: nacos.docus.cn
namespace: 34acdf7a-9fc6-4bbd-8aea-9a47c8007ad5
config:
server-addr: ${spring.cloud.nacos.discovery.server-addr}
namespace: 34acdf7a-9fc6-4bbd-8aea-9a47c8007ad5
file-extension: yml
shared-configs:
- comm.${spring.cloud.nacos.config.file-extension}
profiles:
active: dev
mybatis-plus:
configuration:
map-underscore-to-camel-case: true
call-setters-on-nulls: true
log-impl: org.apache.ibatis.logging.stdout.StdOutImpl
global-config:
db-config:
field-strategy: NOT_EMPTY
db-type: MYSQL
xxl:
job:
accessToken:
admin:
addresses: http://job.docus.cn:8180/xxl-job-admin
executor:
appname: docus-task-ydzyy
address:
ip:
port: 19999
logretentiondays: 30
logpath: D:/xxl-job/docus-task-ydzyy
docus:
dispose:
# 采集任务的方式(大写) 视图VIEW 无视图NO_VIEW默认为 视图 VIEW
pattern: NO_VIEW
url:
downloadplatform:
makeupdown: http://127.0.0.1:9291/api/down/makeUpDownForDown

@ -0,0 +1,2 @@
# If you use SLF4J. First, you need to tell log4jdbc-log4j2 that you want to use the SLF4J logger
log4jdbc.spylogdelegator.name=net.sf.log4jdbc.log.slf4j.Slf4jSpyLogDelegator

@ -0,0 +1,76 @@
<?xml version="1.0" encoding="UTF-8"?>
<configuration debug="false" scan="true" scanPeriod="1 seconds">
<contextName>docus-task-ydzyy</contextName>
<property name="log.path" value="logs/logback"/>
<appender name="console" class="ch.qos.logback.core.ConsoleAppender">
<encoder>
<pattern>[%d{yyyy-MM-dd' 'HH:mm:ss.sss}] [%contextName] [%thread] [%X{traceId}] %-5level %logger{36} - %msg%n</pattern>
</encoder>
</appender>
<appender name="file" class="ch.qos.logback.core.rolling.RollingFileAppender">
<encoder>
<!-- 指定日志输出格式 -->
<pattern>[%d{yyyy-MM-dd' 'HH:mm:ss.sss}] [%C] [%t] [%X{traceId}] [%L] [%-5p] %m%n</pattern>
<charset>utf-8</charset>
</encoder>
<!-- 指定收集策略:滚动策略-->
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
<!--指定生成日志保存地址 -->
<fileNamePattern>${log.path}%d.%i.log</fileNamePattern>
<timeBasedFileNamingAndTriggeringPolicy
class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
<maxFileSize>500MB</maxFileSize>
</timeBasedFileNamingAndTriggeringPolicy>
<MaxHistory>30</MaxHistory>
</rollingPolicy>
</appender>
<springProfile name="dev">
<root level="debug">
<appender-ref ref="console"/>
</root>
</springProfile>
<springProfile name="test|prod">
<root level="INFO">
<appender-ref ref="file"/>
</root>
</springProfile>
<!-- 监控sql日志输出-->
<!-- 如想看到表格数据将OFF改为INFO -->
<logger name="jdbc.resultsettable" level="OFF" additivity="false">
<appender-ref ref="console"/>
</logger>
<!-- 包含 SQL 语句实际的执行时间 及sql语句与jdbc.sqlonly功能重复 -->
<logger name="jdbc.sqltiming" level="OFF" additivity="false">
<appender-ref ref="file"/>
</logger>
<!-- 仅仅记录 SQL 语句,会将占位符替换为实际的参数-->
<logger name="jdbc.sqlonly" level="OFF" additivity="false">
<appender-ref ref="console"/>
</logger>
<!-- 包含 ResultSet 的信息,输出篇幅较长 -->
<logger name="jdbc.resultset" level="OFF" additivity="false">
<appender-ref ref="console"/>
</logger>
<!-- 输出了 Connection 的 open、close 等信息 -->
<logger name="jdbc.connection" level="OFF" additivity="false">
<appender-ref ref="console"/>
</logger>
<!-- 除了 ResultSet 之外的所有JDBC调用信息篇幅较长 -->
<logger name="jdbc.audit" level="OFF" additivity="false">
<appender-ref ref="console"/>
</logger>
</configuration>

@ -0,0 +1,54 @@
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.docus.server.archive.mapper.AfCollectTaskMapper">
<insert id="saveBatch">
INSERT INTO docus_archivefile.af_collect_task
(id, patient_id, af_archive_detail_id, sysflag,state, sync_time, create_time, remark, pResult, C1, C2, C3, C4, C5, C6, C7, C8, C9, C10, T1, T2)
VALUES
<foreach collection="tasks" separator="," item="task">
(
#{task.id}, #{task.patientId},0, #{task.sysflag}, '0', #{task.syncTime}, #{task.createTime}, '', '',
#{task.c1}, #{task.c2}, #{task.c3}, #{task.c4}, #{task.c5}, #{task.c6}, #{task.c7}, #{task.c8}, #{task.c9}, #{task.c10}, #{task.t1}, #{task.t2}
)
</foreach>
</insert>
<update id="update">
<foreach collection="tasks" item="task" separator=";" >
UPDATE docus_archivefile.af_collect_task
SET state=#{task.state}, sync_time=#{task.syncTime}, pResult=#{task.presult},
C1=#{task.c1}, C2=#{task.c2}, C3=#{task.c3}, C4=#{task.c4}, C5=#{task.c5}, C6=#{task.c6}, C7=#{task.c7}, C8=#{task.c8}, C9=#{task.c9}, C10=#{task.c10},
T1=#{task.t1}, T2=#{task.t2}
WHERE id=#{task.id}
</foreach>
</update>
<update id="cancelTask">
UPDATE `docus_archivefile`.`af_collect_task` set state='4'
WHERE id IN
<foreach collection="taskIds" item="taskId" open="(" close=")" separator=",">
#{taskId}
</foreach>
</update>
<update id="cancelFile">
UPDATE `docus_archivefile`.`t_scan_assort` SET is_del = '1'
WHERE taskid IN
<foreach collection="taskIds" item="taskId" open="(" close=")" separator=",">
#{taskId}
</foreach>
</update>
<select id="findByPatientIds" resultType="com.docus.server.archive.entity.AfCollectTask">
SELECT *
FROM
`docus_archivefile`.`af_collect_task`
WHERE
patient_id IN
<foreach collection="patientIdList" item="patientId" separator="," open="(" close=")">
#{patientId}
</foreach>
</select>
</mapper>

@ -0,0 +1,133 @@
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.docus.server.synclis.mapper.LisViewMapper">
<select id="getZyDataFromView" resultType="com.docus.server.synclis.entity.LisView">
SELECT
patient_id AS patientId,
lab_num AS labNum,
name,
hst_num AS hstNum,
req_num AS reqNum,
req_date AS reqDate,
audit_time AS auditTime,
CheckName AS checkName,
PatSource AS patSource,
IDCARD AS idCard
FROM dbo.v_LISReport_YDZYView
WHERE PatSource = '住院'
AND hst_num = #{inpatientNo}
AND Audit_time != ''
AND Audit_time IS NOT NULL
AND Audit_time >= '2022-10-01'
AND req_date >= #{admissDate}
AND req_date &lt;= #{disDate}
ORDER BY audit_time DESC
</select>
<select id="getMzDataFromView" resultType="com.docus.server.synclis.entity.LisView">
SELECT
patient_id AS patientId,
lab_num AS labNum,
name,
hst_num AS hstNum,
req_num AS reqNum,
req_date AS reqDate,
audit_time AS auditTime,
CheckName AS checkName,
PatSource AS patSource,
IDCARD AS idCard
FROM hylisproc.dbo.v_LISReport_YDZYView
WHERE PatSource IN ('门诊','急诊')
AND IDCARD =#{idCard}
AND IDCARD != ''
AND IDCARD IS NOT NULL
AND Audit_time != ''
AND Audit_time IS NOT NULL
AND Audit_time >= '2022-10-01'
AND req_date >= #{startDate}
AND req_date &lt;= #{endDate}
ORDER BY audit_time DESC
</select>
<select id="getFullZyData" resultType="com.docus.server.synclis.entity.LisView">
SELECT
patient_id AS patientId,
lab_num AS labNum,
name,
hst_num AS hstNum,
req_num AS reqNum,
req_date AS reqDate,
audit_time AS auditTime,
CheckName AS checkName,
PatSource AS patSource,
IDCARD AS idCard
FROM
(
SELECT
a.patient_id,
a.lab_num,b.name,
a.hst_num,
ISNULL(a.req_num,'') AS req_num,
a.req_date,
CONVERT(VARCHAR(19),a.audit_time,120) AS audit_time,
dbo.fnGetChkTypeNameByLabNum(a.lab_num) AS CheckName,
ISNULL(c.name,'') AS PatSource,
ISNULL(b.id_card,'') as IDCARD
FROM hylisdb..patient_register a WITH(NOLOCK)
JOIN hylisdb..patient_baseinfo b WITH(NOLOCK) ON a.patient_id=b.patient_id
JOIN hylisdb..ill_type c ON a.send_type=c.type_id
WHERE
a.hst_num = #{inpatientNo}
AND c.name = '住院'
AND a.req_date >= #{admissDate}
AND a.req_date &lt;= #{disDate}
AND a.proc_flag = '8'
) temp
WHERE
Audit_time != ''
AND Audit_time IS NOT NULL
AND Audit_time >= '2022-10-01'
ORDER BY audit_time DESC
</select>
<select id="getFullMzData" resultType="com.docus.server.synclis.entity.LisView">
SELECT
patient_id AS patientId,
lab_num AS labNum,
name,
hst_num AS hstNum,
req_num AS reqNum,
req_date AS reqDate,
audit_time AS auditTime,
CheckName AS checkName,
PatSource AS patSource,
IDCARD AS idCard
FROM
(
SELECT
a.patient_id,
a.lab_num,b.name,
a.hst_num,
ISNULL(a.req_num,'') AS req_num,
a.req_date,
CONVERT(VARCHAR(19),a.audit_time,120) AS audit_time,
dbo.fnGetChkTypeNameByLabNum(a.lab_num) AS CheckName,
ISNULL(c.name,'') AS PatSource,
ISNULL(b.id_card,'') as IDCARD
FROM hylisdb..patient_register a WITH(NOLOCK)
JOIN hylisdb..patient_baseinfo b WITH(NOLOCK) ON a.patient_id=b.patient_id
JOIN hylisdb..ill_type c ON a.send_type=c.type_id
WHERE
b.id_card = #{idCard}
AND c.name IN ('门诊','急诊')
AND a.req_date >= #{startDate}
AND a.req_date &lt;= #{endDate}
AND a.proc_flag = '8'
) temp
WHERE
Audit_time != ''
AND Audit_time IS NOT NULL
AND Audit_time >= '2022-10-01'
ORDER BY audit_time DESC
</select>
</mapper>

@ -0,0 +1,43 @@
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.docus.server.archive.mapper.TBasicMapper">
<sql id="basicInfoColumns">
patient_id AS patientId,
admiss_times AS admissTimes,
inpatient_no AS inpatientNo,
admiss_id AS admissId,
admiss_date AS admissDate,
dis_date AS disDate,
admiss_dept_name AS admissDeptName,
dis_dept_name AS disDeptName ,
jzh,
name,
id_card AS idCard
</sql>
<select id="getByDisDate" resultType="com.docus.server.archive.entity.TBasic">
SELECT
<include refid="basicInfoColumns"></include>
FROM
docus_medicalrecord.t_basic
WHERE
dis_date BETWEEN #{start} AND #{end}
AND admiss_date IS NOT NULL
AND is_cancel = 0
ORDER BY dis_date DESC
</select>
<select id="getByPatientIds" resultType="com.docus.server.archive.entity.TBasic">
SELECT
<include refid="basicInfoColumns"></include>
FROM
docus_medicalrecord.t_basic
WHERE
patient_id IN
<foreach collection="patientIdList" item="patientId" separator="," open="(" close=")">
#{patientId}
</foreach>
ORDER BY dis_date DESC
</select>
</mapper>

Binary file not shown.
Loading…
Cancel
Save