1.准备工作

1.1 本机安装vs2019:(https://visualstudio.microsoft.com/zh-hans/)

1.2 本机安装win64的MariaDB 10.3.27版本数据库:(https://mariadb.com/downloads/)

1.3 本机下载MariaDB数据库的JDBC驱动MariaDB Connector/J 2.7.1版本:(https://mariadb.com/kb/en/mariadb-connector-j-271-release-notes/)

2.在Mirth中添加MariaDB数据库的JDBC驱动jar包

2.1 停止Mirth服务

2.2 把1.3下载的mariadb-java-client-2.7.1.jar包拷贝到F:\MirthConnect\server- lib\database目录,如图所示:

然后修改F:\MirthConnect\conf\dbdrivers.xml文件,添加一条Mariadb的JDBC驱动信息:

<driver class="org.mariadb.jdbc.Driver" name="MariaDB" template="jdbc:mariadb://host:port/dbname" selectLimit="SELECT * FROM ? LIMIT 1" alternativeClasses="com.mysql.jdbc.Driver" />

2.3 重启Mirth服务

3.在MariaDB数据库创建测试用数据库

双击桌面HeidiSQL应用图标执行:

-- 创建 mirthtestdb 数据库

CREATE DATABASE IF NOT EXISTS `mirthtestdb`;

USE `mirthtestdb`;

-- 创建 mirthtestdb.patient 表

CREATE TABLE IF NOT EXISTS `patient` (

`pid` int(11) NOT NULL AUTO_INCREMENT,

`name` varchar(50) DEFAULT NULL,

`sex` varchar(10) DEFAULT NULL,

`dob` varchar(12) DEFAULT NULL,

`addr` varchar(50) DEFAULT NULL,

`ssn` varchar(50) DEFAULT NULL,

`status` tinyint(4) DEFAULT 0,

PRIMARY KEY (`pid`)

) ENGINE=InnoDB AUTO_INCREMENT=107 DEFAULT CHARSET=utf8;

-- 插入 mirthtestdb.patient 表的测试用数据:

DELETE FROM `patient`;

INSERT INTO `patient` (`pid`, `name`, `sex`, `dob`, `addr`, `ssn`, `status`) VALUES

(103, 'Amarnath Zhao', 'M', '19910518', '臺灣', '886', -3),

(104, 'HariGanesh Qian', 'M', '19860712', 'UK', '44 ', -3),

(105, 'Andrew Sun', 'M', '20000225', '大陆', '86', -3),

(106, 'Stiffiny Li', 'F', '20200113', 'RU', '07', -3);

===================================

-- 创建 mirth_business_testdb 数据库

CREATE DATABASE IF NOT EXISTS `mirth_business_testdb`;

USE `mirth_business_testdb`;

-- 创建 mirth_business_testdb.b_patient 表

CREATE TABLE IF NOT EXISTS `b_patient` (

`pid` int(11) NOT NULL AUTO_INCREMENT,

`name` varchar(50) DEFAULT NULL,

`sex` varchar(10) DEFAULT NULL,

`dob` varchar(12) DEFAULT NULL,

`addr` varchar(50) DEFAULT NULL,

`ssn` varchar(50) DEFAULT NULL,

`status` tinyint(4) DEFAULT 0,

PRIMARY KEY (`pid`) USING BTREE

) ENGINE=InnoDB AUTO_INCREMENT=107 DEFAULT CHARSET=utf8;

=================================================================================

赋予root用户远程访问权限:

grant all on mirth_business_testdb.* to 'root'@'%' identified by '125353Ct';

FLUSH PRIVILEGES;

grant all on mirthtestdb.* to 'root'@'%' identified by '125353Ct';

FLUSH PRIVILEGES;

4.让我们通过完成一个接口任务的示例,开始Mirth的使用,并在此过程中培养起学习兴趣

4.1 示例描述:

同步两个数据库的表数据。首先我们通过定时刷库提取mirthtestdb数据库中patient表中字段 status的值为0的行;其次按照第三方webservice接口要求组织入参并发送到此webservice服务,由此webservice服务内部完成对mirth_business_testdb数据库中b_patient表的插入逻辑;最后根据webservice响应值更新mirthtestdb数据库中patient表字段 status的值为1,表明已经提取成功。

4.2 技术要点:

定时刷库提取用Mirth的Database Reader信道实现;第三方webservice接口在vs2019中用C#编程实现。

5.开始完成任务之旅

5.1 在确保Mirth服务已启动的前提下,以管理员模式启动F:\MirthConnect\AdministratorLauncher目录中的mirth administrator launcher程序launcher.exe,如图所示:

5.2 新建Group组Lesson Two:Mirth Connect Cultivate interest(db&soap);

中文释义,第二课:培养学习Mirth的兴趣(从Database Reader Web Service Sender 两种类型Channel讲起)

5.3在Lesson Two Group下New Channel新建信道,如图所示:

(图示:新建信道Channel)

(图示:信道摘要Summary)

(图示:设置信道输入参数格式和输出参数格式)

(图示:设置Source源通道信息)

update patient set status=-1 where pid=${patient_pid}

(图示:快速生成查询SQL语句)

(图示:Edit Transformer 编辑Source Channel源通道入参消息模板到出参消息模板的转换步骤)

(图示:Edit Souce Transformer 编辑转换步骤)

<?xml version="1.0" encoding="UTF-8"?>

<result>

<pid>value</pid>

<name>value</name>

<sex>value</sex>

<dob>value</dob>

<addr>value</addr>

<ssn>value</ssn>

<status>value</status>

</result>

(图示:Edit Destinations 目标通道步骤)

(图示:Edit Response 处理webservice响应信息)

(图示:Edit Response 处理webservice响应信息,连接数据库更新字段status值为1 )

var dbConn=DatabaseConnectionFactory.createDatabaseConnection('org.mariadb.jdbc.Driver', 'jdbc:mariadb://127.0.0.1:3306/mirthtestdb', 'root', '125353Ct');

var pid=msg.*::['Body'].*::['ReceiveMessageResponse'].*::['ReceiveMessageResult'].toString();

if(pid != '-1')

{

var icount=dbConn.executeUpdate("update patient set status=1 WHERE pid = "+pid);

if(icount!=1)

{

logger.error('pid:'+pid);

}

dbConn.close();

}

特别说明:如果在Source源信道信息中设置中没有设置Never选项,则以上javascript脚本更新status=1会马上变为-1。

这也就说明了Source源信道这个设置是在执行了目的信道的响应处理后又执行的。

第二課:Mirth培養興趣之旅 ——由定時刷庫接口編程講起的更多相关文章

  1. gym101522 [小熊骑士限定]La Salle-Pui Ching Programming Challenge 培正喇沙編程挑戰賽 2017

    西瓜队(划掉),Kuma Rider久违的第一场训练,四小时瞎打.jpg A.水题,排序 #include<cstdio> #include<iostream> #includ ...

  2. Codeforces Gym101522 D.Distribution of Days-算日期 (La Salle-Pui Ching Programming Challenge 培正喇沙編程挑戰賽 2017)

    D.Distribution of Days The Gregorian calendar is internationally the most widely used civil calendar ...

  3. Codeforces Gym101522 C.Cheering-字符串 (La Salle-Pui Ching Programming Challenge 培正喇沙編程挑戰賽 2017)

    C.Cheering To boost contestants' performances in the 20th La Salle - Pui Ching Programming Challenge ...

  4. Codeforces Gym101522 A. Ambiguous Dates (La Salle-Pui Ching Programming Challenge 培正喇沙編程挑戰賽 2017)

    A. Ambiguous Dates There are two popular formats for representing a date: day/month/year or month/da ...

  5. MSSS攝影大賽計劃書(第三版)

    比賽內容:對香港的城市風景以及自然風光的攝影 預期成果: 提升同學對香港的認識,鼓勵學生走出大學學園去瞭解香港,同時豐富會員的課餘活動,培養同學的興趣愛好 比賽時間:4月1-15日 最後作品提交時間: ...

  6. VLC祥解

    功能部份:   VLC媒體播放器的核心是libvlc ,它提供了界面,應用處理功能,如播放列表管理,音頻和視頻解碼和輸出,線程系統.所有libvlc源文件設在的/src目錄及其子目錄:   # con ...

  7. [SharePoint 2010] SharePoint 2010上多人同時編輯Office 2010文件

    Office 2010這個版本,提供了一個令人興奮的新功能,那就是它可以讓多人同時編輯一份Office 2010的文件. 這是一個很大的突破. 以往在與SharePoint搭配下的分享環境,檔案只能被 ...

  8. 邁向IT專家成功之路的三十則鐵律 鐵律十二:IT人養生之道-德行

    所謂的「養生」在中國古代裡所指的是針對內在精神層面修為的提升,到了近代中醫所謂的養生,則除了包含最根本的內在精神層面之外,還涵蓋了外在身體的養護.在現今各行各業的人士當中,嚴格來說都應該要有一套專屬的 ...

  9. 我要成为前端工程师!给 JavaScript 新手的建议与学习资源整理

    来源于:http://blog.miniasp.com/post/2016/02/02/JavaScript-novice-advice-and-learning-resources.aspx 今年有 ...

  10. GOOGLE搜索從入門到精通V4.0

    1,前言2,摘要3,如何使用本文4,Google簡介5,搜索入門6,初階搜索 6.1,搜索結果要求包含兩個及兩個以上關鍵字 6.2,搜索結果要求不包含某些特定資訊 6.3,搜索結果至少包含多個關鍵字中 ...

随机推荐

  1. labeImg 遇到闪退问题,TypeError: setValue(self, a0: int): argument 1 has unexpected type 'float'

    将python 环境安装为python3.9,然后重新安装labelImg

  2. KETTLE实战视频教程--免费白嫖(本贴持续更新)

    KETTLE实战视频教程 欢迎关注笔者的公众号: java大师, 每日推送java.kettle运维等领域干货文章,关注即免费无套路附送 100G 海量学习.面试资源哟!!个人网站: http://w ...

  3. api-ms-win-crt-***.dll, api-ms-win-core-***.dll,win7以后kernel.dll,msvc*.dll的改变。api-ms-win-crt-***.dll 有问题就是 c++ redist 版本过低。

    api-ms-win-crt-***-|1-1-0.dll是redistributable c++的一部分.以往只会因为msvc*NNN.dll才要去找对应的redistributable c++版本 ...

  4. FFmpeg 基本操作摘要(一) (转流、解码、编码)

    PS:要转载请注明出处,本人版权所有. PS: 这个只是基于<我自己>的理解, 如果和你的原则及想法相冲突,请谅解,勿喷. 前置说明   本文作为本人csdn blog的主站的备份.(Bl ...

  5. 记录--前端中 JS 发起的请求可以暂停吗

    这里给大家分享我在网上总结出来的一些知识,希望对大家有所帮助 在前端中,JavaScript(JS)可以使用XMLHttpRequest对象或fetch API来发起网络请求.然而,JavaScrip ...

  6. R语言数据质量分析

    数据质量分析是数据预处理的前提,也是数据分析结论有效性和准确性的基础. 数据质量分析的主要任务是检查原始数据中是否存在脏数据. 脏数据一般包括: 缺失值分析 缺失值产生的原因.影响 原因: 部分信息难 ...

  7. 如何用Flask中的Blueprints构建大型Web应用

    本文分享自华为云社区<构建大型Web应用Flask中的Blueprints指南>,作者: 柠檬味拥抱. 什么是Blueprints? Blueprints是Flask中的一种模式,用于将应 ...

  8. Dynamic ReLU:微软推出提点神器,可能是最好的ReLU改进 | ECCV 2020

    论文提出了动态ReLU,能够根据输入动态地调整对应的分段激活函数,与ReLU及其变种对比,仅需额外的少量计算即可带来大幅的性能提升,能无缝嵌入到当前的主流模型中   来源:晓飞的算法工程笔记 公众号 ...

  9. KingbaseES数据库导入数据invalid byte sequence for encoding

    一.适用版本: KingbaseES数据库所有版本. 二.问题现象: 使用备份的数据进行还原,还原过程中发生异常. 日志信息: sys_restore: connecting to database ...

  10. 探秘Kubernetes:在本地环境中玩转容器技术

    在云计算时代,Kubernetes 已成为云原生技术的真正基石.它是应用程序容器的编排动力源,可跨多个集群自动部署.扩展和运行容器.Kubernetes 不仅仅是一个流行词,它还是一种模式转变,是现代 ...