1、 591 论文网 www.591LW.com本市 A 医学内部人力资源管理系统的设计摘 要随着信息科学技术的飞速发展,人们逐渐意识到对信息管理软件的运用可以使日常工作更加方便、快捷和高效。论文详细论述了一个基于 C/S 结构的医院管理系统的开发设计过程。系统采用 Visual Basic 6.0 作开发平台,SQL Server 2000 作数据库管理系统,实现了病人登记、医生信息管理、病人就诊信息管理、住院信息管理等功能。系统符合医院管理的要求,能够帮助医院切实提高工作效率。论文组织如下:首先阐述了该系统的开发背景、意义;其次介绍了相关的开发工具及技术基础;接着对系统的需求进行了分析,并提出
2、了具体的设计方案和数据库模型;然后展现了整个系统的具体实现,包括数据库的设计和连接,各功能模块的实现;最后对该软件进行了严格的测试。关键词:医院管理系统;Visual basic ;SQL server 2000591 论文网 www.591LW.comThe Design and Implementation of Hospital Management System based on C/SAbstractAlong with the rapid development of the information science technology, people gradually real
3、ize that the utilization of information management software could make the routine more convenient, quick and efficient. The paper discusses in detail the development and design process of a hospital management system based on C/S structure. It uses Visual Basic 6.0 as the development platform, SQL
4、Server 2000 as the database management system, and includes patients registration management, doctors information management, diagnosis information management and hospitalization information management, etc It can accord with the requirement of hospital management, and can help hospital enhance its
5、work efficiency.The paper is organized as following: Firstly, analyzes the background and significance; Secondly, introduces the development tools and the foundation of the technology; Thirdly, analyses the demand of the system, gives a specific design project and a database model; Then shows the im
6、plementation of the whole system, which includes the design and linkage of the database and the implementation of every module. Finally gives a test of the system.Key words: Hospital management system; Visual basic; SQL server 2000591 论文网 www.591LW.com目 录论文总页数:25 页1 引言 12 系统理论基础及开发工具简介 12.1 C/S 结构 1
7、2.1.1 什么是 C/S 结构 12.1.2 C/S 架构软件的优势与劣势 12.2 VISUAL BASIC 的介绍 .22.3 SQL SERVER2000 简介 43 系统需求分析与方案设计 43.1 需求分析 43.2 方案设计 43.3 可行性研究 53.3.1 技术可行性方面 53.3.2 经济可行性 63.3.3 操作上的可行性 64 系统的实现 64.1 数据库的构建 64.1.1 IHMS_Users 表 .64.1.2 Disease 表 64.1.3 Doctor 表 .74.1.4 Patient_Hospital_History 表 .74.1.5 Patient_
8、Lab_Info 表 .74.1.6 Patient_Personal_Info 表 84.1.7 Symptoms 表 .84.2 系统登陆模块 84.2.1 启动界面 84.2.2 系统主界面 94.2.3 登陆界面 .104.2.4 系统管理员权限界面 .114.3 医生 信息模块 .114.4 病人登记管理模块 .124.5 病人就诊信息模块 .134.6 病人住院信息管理模块 .144.7 病人出院信息管理模块 .175 系统测试 .18591 论文网 www.591LW.com5.1 测试环境 .185.1.1 硬件环境 .185.1.2 软件环境 .185.2 模块测试 .185
9、.2.1 系统登陆及管理员权限测试 .185.2.2 医生用户信息测试 .195.2.3 新增病人用户信息测试 .195.2.4 病人就诊信息测试 .205.2.5 病人住院信息测试 .205.2.6 病人出院信息测试 .21结 论 .22参考文献 .22591 论文网 www.591LW.com第 5 页 共 25 页1 引言自从人类进入 21 世纪,也就进入了一个高速发展的信息时代,高新技术飞速发展的同时,也使得计算机的使用范围大大扩展,它已经涉及到人类生活的方方面面。计算机使用的方便快捷,使它在越来越多的方面显示出比传统人工制作更迅速和准确的优点,尤其是在信息记录,检索和查询方面,更是使
10、我们人类避免了不必要的麻烦。开发和使用医院管理系统对于医院来说是非常必要的,它能加快医院的信息化步伐,提高医院的管理水平和医疗水平,增强在同行业中的竞争实力,是现代医院管理与计算机信息技术的必要结合。医院管理系统能加强医院内部管理、提高医疗服务水平,最大限度地提高医院运行的效率和医院管理水平,给医院带来了显著的经济效益和社会效益,也能使医院在未来竞争中处于领先地位。本课题设计一个医院管理系统,通过这个系统管理员可以简捷、方便的对病人、医生的记录进行查阅、增加、删除等功能,而用户也可以通过这个系统对进医生和病人的信息查询、账户增删等功能。系统采用 Visual Basic 作开发工具,SQL S
11、erver 2000 作数据库管理系统。2 系统理论基础及开发工具简介2.1 C/S 结构2.1.1 什么是 C/S 结构C/S(Client/Server)结构,即大家熟知的“客户机和服务器”结构,它是软件系统体系结构,通过它可以充分利用两端硬件环境的优势,将任务合理分配到 Client 端和 Server 端来实现,降低了系统的通讯开销。目前大多数应用软件系统都是 Client/Server 形式的两层结构,由于现在的软件应用系统正在向分布式的 Web 应用发展,Web 和 Client/Server 应用都可以进行同样的业务处理,应用不同的模块共享逻辑组件,因此,内部的和外部的用户都可以
12、访问新的和现有的应用系统,通过现有应用系统中的逻辑可以扩展出新的应用系统,这也就是目前应用系统的发展方向。2.1.2 C/S 架构软件的优势与劣势(1)应用服务器运行数据负荷较轻。最简单的 C/S 体系结构的数据库应用由两部分组成,即客户应用程序和数据库服务器程序,二者可分别称为前台程序与后台程序。运行数据库服务器程序的机器,也称为应用服务器。一旦服务器程序被启动,就随时等待响应客户程序发来的请求;客户应用程序运行在用户自己的电脑上,对应于数据库服务器,可称为客户电脑,当需要对数据库中591 论文网 www.591LW.com第 6 页 共 25 页的数据进行任何操作时,客户程序就自动地寻找服
13、务器程序,并向其发出请求,服务器程序根据预定的规则作出应答,送回结果,应用服务器运行数据负荷较轻。(2)数据的储存管理功能较为透明。在数据库应用中,数据的储存管理功能,是由服务器程序和客户应用程序分别独立进行的,前台应用可以违反的规则,并且通常把那些不同的运行数据在服务器程序中不集中实现,例如访问者的权限、编号可以重复、必须有客户才能建立定单这样的规则。所有这些,对于工作在前台程序上的最终用户,是“透明”的,他们无须过问(通常也无法干涉)背后的过程,就可以完成自己的一切工作。在客户服务器架构的应用中,前台程序不是非常“瘦小”,麻烦的事情都交给了服务器和网络。在 C/S 体系的下,数据库不能真正
14、成为公共、专业化的仓库,它受到独立的专门管理。(3)C/S 架构的劣势是高昂的维护成本且投资大。首先,采用 C/S 架构,要选择适当的数据库平台来实现数据库数据的真正“统一”,使分布于两地的数据同步完全交由数据库系统去管理,但逻辑上两地的操作者要直接访问同一个数据库才能有效实现,有这样一些问题,如果需要建立“实时”的数据同步,就必须在两地间建立实时的通讯连接,保持两地的数据库服务器在线运行,网络管理工作人员既要对服务器维护管理,又要对客户端维护和管理,这需要高昂的投资和复杂的技术支持,维护成本很高,维护任务量大。其次,传统的C/S 结构的软件需要针对不同的操作系统系统开发不同版本的软件,由于产
15、品的更新换代十分快,代价高和低效率已经不适应工作需要。2.2 Visual Basic 的介绍Visual Basic(VB)是一种由微软公司开发的包含协助开发环境的事件驱动编程语言。从任何标准来说,VB 都是世界上使用人数最多的语言不仅是盛赞 VB 的开发者还是抱怨 VB 的开发者的数量。它源自于 BASIC 编程语言。VB拥有图形用户界面(GUI)和快速应用程序开发(RAD)系统,可以轻易的使用DAO、RDO、ADO 连接数据库,或者轻松的创建 ActiveX 控件。程序员可以轻松的使用 VB 提供的组件快速建立一个应用程序。一个典型的 VB 进程 VB 的中心思想就是要便于程序员使用,无
16、论是新手或者专家。VB 使用了可以简单建立应用程序的 GUI 系统,但是又可以开发相当复杂的程序。VB 的程序是一种基于窗体的可视化组件安排的联合,并且增加代码来指定组建的属性和方法。因为默认的属性和方法已经有一部分定义在了组件内,所以程序员不用写多少代码就可以完成一个简单的程序。过去的版本里面VB 程序的性能问题一直被放在了桌面上,但是随着计算机速度的飞速增加,关于性能的争论已经越来越少。591 论文网 www.591LW.com第 7 页 共 25 页窗体控件的增加和改变可以用拖放技术实现。一个排列满控件的工具箱用来显示可用控件(比如文本框或者按钮) 。每个控件都有自己的属性和事件。默认的
17、属性值会在控件创建的时候提供,但是程序员也可以进行更改。很多的属性值可以在运行时候随着用户的动作和修改进行改动,这样就形成了一个动态的程序。举个例子来说:窗体的大小改变事件中加入了可以改变控件位置的代码,在运行时候每当用户更改窗口大小,控件也会随之改变位置。在文本框中的文字改变事件中加入相应的代码,程序就能够在文字输入的时候自动翻译或者阻止某些字符的输入。VB 的程序可以包含一个或多个窗体,或者是一个主窗体和多个子窗体,类似于操作系统的样子。有很少功能的对话框窗口(比如没有最大化和最小化按钮的窗体)可以用来提供弹出功能VB 的组件既可以拥有用户界面,也可以没有。这样一来服务器端程序就可以处理增
18、加的模块。VB 使用参数计算的方法来进行垃圾收集,这个方法中包含有大量的对象,提供基本的面向对象支持。因为越来越多组建的出现,程序员可以选用自己需要的扩展库。和有些语言不一样,VB 对大小写不敏感,但是能自动转换关键词到标准的大小写状态,以及强制使得符号表入口的实体的变量名称遵循书写规则。默认情况下字符串的比较是对大小写敏感的,但是可以关闭这个功能。一些术语:控件简单的说,控件就是构成或者说建造 Visual Basic 应用程序的图形化工具,包括窗体、按钮、复选框、列表框、数据控件、表格控件和图片控件等等;事件由用户或操作系统引发的动作。事件的示例有击键、单击鼠标(Click)、双击鼠标(D
19、blClick)、一段时间的限制,或从端口接收数据;方法嵌入在对象定义中的程序代码,它定义对象怎样处理信息并响应某事件。例如,数据库对象有打开纪录集并从一个记录移动到另一个记录的方法程序的基本元素,它含有定义其特征的属性,定义其任务和识别它可以响应的事件的方法。控件和窗体是 Visual Basic 中所有对象的示例;对象一个控件、窗体等都可被看作一个对象;过程为完成某些特定的任务而编写的代码段,过程通常用于响应特定的事件,也可以当作应用程序的用户自定义函数来使用;属性属性是组成用户界面的各对象的性质的具体描述。例如上述“对象”中所提到的尺寸、位置、颜色、宽度、高度等等都称为控件的 属性。属性
20、决定对象的外观,有时也决定对象的行为。对象的属性绝大部分是 VB 中已经事591 论文网 www.591LW.com第 8 页 共 25 页先定义好的,但也有的属性是需要在应用 过程中才去定义的。属性即可为对象提供数据,也能从对象取回信息。2.3 SQL Server2000 简介SQL Server 是一个关系数据库管理系统,是 Microsoft 推出新一代数据管理与分析软件。SQL Server 是一个全面的、集成的、端到端的数据解决方案,它为企业中的用户提供了一个安全、可靠和高效的平台用于企业数据管理和商业智能应用。SQL Server 2000 是一个全面的、集成的、端到端的数据解决
21、方案,它为企业中的用户提供了一个安全、可靠和高效的平台用于企业数据管理和商业智能应用。SQL Server 2000 为 IT 专家和信息工作者带来了强大的、熟悉的工具,同时减少了在从移动设备到企业数据系统的多平台上创建、部署、管理及使用企业数据和分析应用程序的复杂度。通过全面的功能集、和现有系统的集成性、以及对日常任务的自动化管理能力,SQL Server 2000 为不同规模的企业提供了一个完整的数据解决方案。SQL Server 2000 数据平台包括如下工具:关系型数据库、复制服务、通知服务、集成服务、分析服务、报表服务、管理工具、开发工具。SQL Server 2000 数据平台为不
22、同规模的组织提供了如下好处:充分利用数据资产、提高生产力、减少 IT 复杂度、更低的总体拥有成本(TCO)。3 系统需求分析与方案设计3.1 需求分析医院管理系统是针对医院要求用计算机对医生和病人的各种信息进行汇总和记录的一种现代化管理软件,主要包括对病人的注册、就诊、住院登记、治疗结果、出院情况等档案信息的添加、记录、修改和查询等。通过对用户需求的分析,要求本系统具有以下功能:(1) 由于一项新的软件在被使用之前,对于使用者来说是陌生和崭新的,所以要求系统具有良好的人机界面;(2) 原始数据修改简单方便,在系统的使用过程中支持多条件查询;(3) 数据计算自动完成,数据的稳定性和可靠性好,尽量
23、减少人工干预。3.2 方案设计具体说来,要求本系统具有以下五个功能模块:门诊模块、医生信息模块、病人登记管理模块、病人就诊信息模块和住院信息管理模块。系统整体的模块图如图 1 所示:591 论文网 www.591LW.com第 9 页 共 25 页各模块具体的需求描述如下:(1)病人登记管理模块:以系统合法的身份进入系统后,可以直接处理新增病人的记录,包括病人各项基本信息;(2)医生信息模块:进入系统之后,可以在本模块进行新医生用户的基本信息诸如姓名、科室、职称、联系方式等的录入,以及通过姓名对医生的信息进行查询;(3)病人就诊信息模块:通过对病人病症的描述,可以判断出病人的疾病情况,做好记录
24、,并可决定是否需要住院治疗;(4)住院信息管理模块:医生确定该病人入院治疗,其中包括对病症的详细描述;(5)出院模块:医生控制该病人的出院信息,包括出院的时间以及出院是的身体状况。3.3 可行性研究3.3.1 技术可行性方面本系统利用 Visual Basic 作为系统的开发工具,是因为它采用面向对象的编程方法把程序和数据封装起来作为一个对象,并为每个对象赋予相应的属性;事件驱动的编程机制通过事件执行对象的操作,在设计应用程序时,不必建立具有明显的开始和结束的程序,而是编写若干个过程,通过这些过程医院管理系统病人就诊信息模块医生信息模块病人登记管理模块住院信息管理出院模块图 1 系统关系图59
25、1 论文网 www.591LW.com第 10 页 共 25 页执行指定的操作;提供完善的指令控制语句,给开发高性能的系统提供了保障,保证了代码的模块化要求。系统采用 SQL Server 2000 作为后台数据库,它可以通过窗体提供的工具输入数据到数据库,可以使用查询设计和结构查询语言实现查询。在技术难度方面,由于有指导老师的指导和相关的参考文献,特别是身边的同学的帮助,使得在开发过程中所遇到的困难都能够一一得到解决。3.3.2 经济可行性随着计算机的大量普及,其价格已经越来越被众多的单位和人所接受,然而价格的低廉并不意味着性能上的退化,相反,随着科学技术的发展,计算机随着价格的降低,性能却
26、日渐提高。本系统的开发,在已经使用了计算机进行管理的医疗系统中无疑会受到欢迎,它会给医院的工作效率带来一个质的飞跃,其主要的优点主要表现在它可以作为医院管理系统基本功能的一个缩影,集成了门诊模块、病人登记管理模块、病人就诊信息模块和住院信息管理模块等多种功能,具有较强的实用性和先进性。由于本系统具有安全性上面的保护措施,只有用户拥有了系统合法的用户名和相应的密码之后,才能进入系统,对系统的对应信息进行添加、修改和删除,其他非合法的用户都不能进入系统,这样,使得医院在处理信息方面更加保密。3.3.3 操作上的可行性由于本系统管理的对象比较单一,都是就诊的病人和相关医务人员,且每个数据库内容具有较
27、强的关联性,设计的过程不是很复杂,因此,比较适合于采用数据库管理。且因为本系统所耗费的资源非常小,故一般工作中使用的微机无论在软件上还是硬件上都可以满足运行要求。4 系统的实现4.1 数据库的构建4.1.1 IHMS_Users 表此表的设计是为了实现本医院管理系统的用户的新增和密码的管理,包括编号(Id)、用户名(Users)、密码(Pass)和科室(Departments):表 1 IHMS_Users 表列名 数据类型 长度 允许空Id int 4Users varchar 20Pass varchar 20Type varchar 50 Departments varchar 50 5
28、91 论文网 www.591LW.com第 11 页 共 25 页4.1.2 Disease 表此表是数据库中“疾病”的信息集合,包括疾病编号(Disease_ID)和疾病名(Disease_Name):表 2 Disease 表列名 数据类型 长度 允许空Disease_ID int 4Diseases_Name varchar 404.1.3 Doctor 表这是“医生信息”表,包括医生的姓名(Name)、性别(Sex)、年龄(Age)、籍贯(Province)、科室(Dept)、手机号(Mobile)和职称(Grade)这一系列的基本信息:表 3 Doctor 表列名 数据类型 长度 允
29、许空SN int 4Name varchar 20Sex int 4 Age int 4 Province varchar 50 Mobile varchar 20 Dept varchar 50 Grade varchar 50 4.1.4 Patient_Hospital_History 表此表是病人出院的时候的信息统计表,包括病历号(Case_Ref_No)、入院时的身体状况(Admission_Status)、入院的时间(Date_of_Admission)、主治医生的姓名(Name_of_Doctor)、医生的备注(Doctors_Diagnosis)、出院的时间(Date_of_D
30、ischarge)以及出院时病人的身体康复情况(Status_Upon_Discharge):表 3 Patient_Hospital_History 表列名 数据类型 长度 允许空Case_Ref_No int 4Hosp_No int 4Admission_Status varchar 10Date_of_Admission datetime 8Name_of_Doctor varchar 30Doctors_Diagnosis varchar 20Date_of_Discharge datetime 8 Status_Upon_Dischargevarchar 30 591 论文网 ww
31、w.591LW.com第 12 页 共 25 页4.1.5 Patient_Lab_Info 表此表是病人的病历表,包括病人的编号(Hosp_No)、血型(Blood_Group)、RH 因子(RhFactor)以及过敏史(Allergy):表 4 Patient_Lab_Info 表列名 数据类型 长度 允许空Lab_Ref_No int 4Hosp_No int 4Blood_Group varchar 10RhFactor varchar 20Allergy varchar 10 4.1.6 Patient_Personal_Info 表此表是病人的基本信息表,包括病人的姓名(SName
32、,FName)、出生日期(Date_Of_Birth)、性别(Sex)、家庭住址(Home_Add)和职业(Occupation):表 5 Patient_Lab_Info 表列名 数据类型 长度 允许空Hosp_No int 4SName varchar 20FName varchar 20Date_Of_Birth datetime 8Sex varchar 10Home_Add varchar 80State_of_Originvarchar 20Occupation varchar 204.1.7 Symptoms 表这是“病情症状”表,对不同病症的描述以便病人就诊时能准确判断其病症所
33、在,包括症状编号(Symptom_ID)、疾病编号(Disease_ID)、症状名(Symptom_Name)和描述(Desrciption)几个方面:表 6 Symptoms 表列名 数据类型 长度 允许空Symptom_ID int 4Disease_ID int 4Symptom_Name varchar 80Desrciption varchar 20 4.2 系统登陆模块4.2.1 启动界面这是整个系统开始运行时出现的第一个界面,是由 frmSplash 具体控制和实现的:591 论文网 www.591LW.com第 13 页 共 25 页图 2 系统启动界面在这个部分,系统会完成与
34、数据库的连接工作,具体的代码实现如下:Private Sub Form_Load()ConnectString = “Provider=SQLOLEDB.1; Password=123; Persist Security Info=True; User ID=sa; Initial Catalog=IHMS;Data Source=(local)“ Me.MousePointer = 11Set somePatient = New CPatientEnd Sub时钟的设计,可以控制从该初始界面进入到系统主界面的时间:Private Sub Timer1_Timer()Unload MeEnd
35、Sub然后,整个系统就进入主界面。4.2.2 系统主界面所谓系统主界面,也就是程序主窗体 frmmain,它是整个系统的主要操作界面,也是在登陆之后首先出现的系统操作界面(图 3),采用菜单结构,简单明了,操作方便:591 论文网 www.591LW.com第 14 页 共 25 页图 3 系统主界面4.2.3 登陆界面该模块具体是由 frmLogin 窗体控制并实现的。本 HIS 系统可供两种身份的用户登陆:一个是 Admin,另一个是医生。二者唯一的权限区别就是 Admin 可以对医生用户进行管理:添加、删除、密码修改。以下实现的是以医生的身份登陆该系统:图 4 登陆对话框Do While
36、 Not .EOF And Not LoginSucceededIf (cboUserName = .Fields(“users“) And Trim(txtPassword) = .Fields(“pass“) ThenTypeStr = .Fields(“Type“) 登陆生效If (TypeStr = “医生“) ThenDepartments = .Fields(“Departments“)End IfMsgBox “登陆成功,欢迎进入系统.“, vbInformation, “欢迎“LoginSucceeded = TrueCall ConfigMenus(cboUserName)5
37、91 论文网 www.591LW.com第 15 页 共 25 页Unload MeEnd If.MoveNextLoop4.2.4 系统管理员权限界面Admin 可以对医生用户进行管理:添加、删除、密码修改:图 5 权限管理4.3 医生信息模块4.4 病人登记管理模块4.5 病人就诊信息模块按照正常的流程,成功登记的病人用户应该就诊。以成功登记的病人,可以通过对病症的描述方式得出初步诊断结果。这部分工作由 frmDiagnosis 窗体具体控制和实现。在这个模块里,对于文本性的信息仍旧使用 TextBox 实现,而对于病症的描述,采取了用五条病症同时描述来实现,每一条病症选择出都采用 Com
38、boBox 来实现,其下拉菜单出将出现 DB 表里所存储的病症的所有描述。591 论文网 www.591LW.com第 16 页 共 25 页图 8 诊断信息Dim symptom(4) As StringDim diseaseID(4) As IntegerDim diseaseName(4) As StringDim diagnosisResults(4) As StringDim X As Integer For X = 0 To 4 symptom(X) = cboSymptom(X)Next XIf symptom(0) = “N/A“ Or symptom(0) = “ Then
39、保证病人至少选择一个病症描述,否则退出MsgBox “You must specify AT LEAST one sign/symptom to diagnose a patient, starting with Symptom 1.“, vbInformationExit SubEnd IfCall DiagnosePatient(symptom(0), diseaseID(0), diseaseName(0)txtDisease(0).Text = diseaseName(0)For X = 1 To 4 根据描述的症状产生出一个诊断结果If symptom(X) diseaseName(
40、0) Then diagnosisResults(X) = diseaseName(X)End IfNext XDim a As Integer, b As IntegerDim temp As StringFor a = 1 To 3For b = 1 To 4 - aIf diagnosisResults(b) diagnosisResults(b + 1) Thentemp = diagnosisResults(b)diagnosisResults(b) = diagnosisResults(b + 1)diagnosisResults(b + 1) = tempElseIf diagn
41、osisResults(b) = diagnosisResults(b + 1) ThentxtDisease(1) = “ 显示结果For a = 1 To 4If diagnosisResults(a) “ Then txtDisease(1) = txtDisease(1) + diagnosisResults(a) + vbCrLfNext aEnd Sub4.6 病人住院信息管理模块经过了医生的诊断,就可以得出病人的病症情况,也就可以决定改病人是否需要住院治疗。这个模块主要是由 frmAdmitExisting 窗体控制和实现的。这个窗体的设计比较简单明了,由病人的主治医师填入住院时
42、间、医师姓名以及一些备注信息后就可以成功给病人办理住院手续。该窗体由几个简单的591 论文网 www.591LW.com第 17 页 共 25 页TextBox 实现所对应的也都是一些文本信息。图 9 病人病例Private Sub cmdConfirmAdmission_Click()With Me.datHospHist.Recordset.Fields(“Hosp_No“) = somePatient.HospNo.Fields(“Admission_Status“) = “IN“.Fields(“Date_of_Admission“) = txtDateOfAdmission.Fiel
43、ds(“Name_of_Doctor“) = txtDoctorInCharge.Fields(“Doctors_Diagnosis“) = txtDoctorsComments.UpdateEnd WithMsgBox “住院手续登记成功.“, vbInformation, “成功“Unload frmOldPatientUnload MeExit Suberrhnd:Debug.Print Err.Number; “ “; Err.DescriptionMsgBox “一个未知错误.“, vbInformation, “未知错误!“Resume NextEnd SubPrivate Sub
44、 datHospHist_1_Validate(Action As Integer, Save As Integer)End SubPrivate Sub Form_Load()lblHeading.Caption = lblHeading.Caption + Str(somePatient.HospNo)datHospHist.ConnectionString = ConnectString591 论文网 www.591LW.com第 18 页 共 25 页datHospHist.RecordSource = “Patient_Hospital_History“datHospHist.Ref
45、reshdatHospHist.Recordset.AddNew显示保存的结果txtCaseRefNo = datHospHist.Recordset.Fields(“Case_Ref_No“)End Sub图 10 住院信息Private Sub cmdConfirmAdmission_Click()With frmNewReg.datPerInfo.Recordset.Fields(“Hosp_No“) = frmNewReg.thisNewPatient.HospNo 病人信息.Fields(“SName“) = frmNewReg.thisNewPatient.SName.Fields
46、(“FName“) = frmNewReg.thisNewPatient.FName.Fields(“Sex“) = frmNewReg.thisNewPatient.Sex.Fields(“Home_Add“) = frmNewReg.thisNewPatient.HomeAdd.Fields(“State_of_Origin“) = frmNewReg.thisNewPatient.StateOfOrigin.Fields(“Occupation“) = frmNewReg.thisNewPatient.Occupation.Fields(“Name_of_NoK“) = frmNewRe
47、g.thisNewPatient.NameNoK 亲属信息.Fields(“Relationship_to_NoK“) = frmNewReg.thisNewPatient.RelaNok.Fields(“Add_of_NoK“) = frmNewReg.thisNewPatient.AddNok.Fields(“Name_of_Sponsor“) = frmNewReg.thisNewPatient.SponsorName 担保人信息.Fields(“Add_of_Sponsor“) = frmNewReg.thisNewPatient.SponsorAddEnd WithWith frmN
48、ewReg.datLabInfo.Recordset.Fields(“Hosp_No“) = frmNewReg.thisNewPatient.HospNo 化验室信息 .Fields(“Blood_Group“) = frmNewReg.thisNewPatient.BloodGrp.Fields(“RhFactor“) = frmNewReg.thisNewPatient.RHFactor.Fields(“Allergy“) = frmNewReg.thisNewPatient.AllergyEnd With591 论文网 www.591LW.com第 19 页 共 25 页With Me.datHospHist.Recordset.Fields(“Hosp_No“) = Val(txtHospNo).Fields(“Admission_Status“) = “IN“.Fields(“Date_of_Admission“) = txtDateOfAdmission.Fields(“Name_of_Doctor“) = txtD