医院预约挂号平台的设计与实现论文(32页).doc
-医院预约挂号平台的设计与实现论文-第 25 页医院预约挂号平台的设计与实现学 生 姓 名: 学 院: 专 业: 班 级: 学 号: 指 导 教 师: 审 阅 教 师: 完 成 日 期: 摘 要进入21世纪以来,网络的空前发展给人们的工作和生活带来了极大的便利,信息化建设已经成为节约运营成本、提高工作效率的首选。相比之下,国内相当数量的中小医院的医院预约挂号工作还采用相对保守的手工工作方式,数据信息查询和存储的成本较高,但效率却很低下。为了使医院预约挂号管理更高效、更科学,决定开发医院预约挂号平台。本文采用结构化分析的方法,详细阐述了一个功能比较强大的医院预约挂号平台的前后台开发、操作流程和涉及的一些关键技术。首先进行了可行性分析,然后是系统分析,通过实际的业务流程调研,分析业务流程和系统的组织结构,完成了数据流分析和数据字典;然后是系统设计阶段主要完成了功能模块的划分、阐述了系统设计的思想、数据库的设计和系统设计的工具及技术。该阶段对本系统各个模块的功能进行了详细设计,形成了本系统的功能模块图;数据库设计时先进行了概念结构设计,然后进行了逻辑结构设计,最后完成了数据表的设计。根据前几个阶段的分析和设计,本系统在设计方面采用B/S模式,同时使用JSP技术进行基本页面的设计与功能实现,后台数据库选用SQL Server 2000数据库。本系统的设计实施为医院预约挂号系统的运行做基础,为医院预约挂号管理工作提供良好的条件。关键词:预约挂号;结构化分析;平台AbstractIn the 21st century, the unprecedented development of the network to the people's work and life has brought great convenience, information technology has become operational cost savings, improve efficiency of choice. In contrast, a considerable number of domestic small and medium hospitals, hospital appointment registration work is relatively conservative with manual work, data query and the high cost of storage, but the efficiency is very low. To make an appointment by registered hospital management more efficient, more science, decided to develop the hospital appointment registration platform.In this paper, structural analysis, a function described in detail more powerful platform for the hospital before and after the appointment register sets and development, operational processes, and some of the key technologies involved. First, a feasibility analysis, and system analysis, business process through the actual research, analyze business processes and organizational structure of the system to complete the data flow analysis and data dictionary; then completed the system design phase is mainly divided into functional modules, elaborated the idea of the system design, database design and system design tools and techniques. This phase of the system function of each module in detail the design, forming a functional block diagram of the system; database design first tested the concept design, followed by a logic design, and finally completed the data table design.According to the first few stages of the analysis and design, the system used in the design of B / S mode, JSP technology, the basic page design and implementation of function, use SQL Server 2000 database backend database. Implementation of the system design registration system for the operation of the hospital appointment as a foundation for the hospital management to provide a good appointment registration conditions.Key Words:Appointment registration; structural analysis; platform目 录摘 要IAbstractII一、引言1(一)项目开发的背景1(二)项目开发的目的1二、可行性分析及总体设计原则2(一)可行性分析21技术可行性22经济可行性23社会可行性3(二)总体设计原则3三、系统分析5(一)业务流程分析5(二)数据流图6(三)数据字典9四、系统设计13(一)系统功能设计13(二)系统数据库设计141概念结构设计142逻辑结构设计183数据库表设计18(三)系统开发工具与开发模式的选择201系统开发工具202系统设计模式21五、系统实现22(一)用户模块221登录及注册管理模块222首界面233用户注册界面244公告界面255科室预约界面266留言界面27(三)管理员模块281登录界面282科室管理界面283添加专家界面29六、性能测试与分析30(一)测试的重要性30(二)测试实例的研究与选择30(三)测试环境与测试条件31(四)实例测试32(五)系统评价32(六)测试结果33参 考 文 献35致 谢36一、引言(一)项目开发的背景随着市场经济的发展,市场竞争压力加大,医院要生存发展,就必须在各个方面加强管理,并要求医院有更高的信息化集成,能够对医院的整体资源进行集成管理。现代医院已意识到,医院间的竞争不仅是医术方面的竞争,更是综合实力的竞争,要求医院有更强的资金实力,更快的市场响应速度。这就要求医院各个科室之间统一计划,协调步骤,汇总信息,调配医院内部资源,实现既要独立又要统一的资源共享管理。随着信息技术的发展,为提高预约挂号管理的管理效率,决定开发“医院预约挂号平台”。用户来医院就诊,有可能排很长时间的队,都不能排上号。所以为了更好的适应信息时代的高效性,一个利用计算机来实现医院预约挂号平台管理工作的系统将必然诞生。基于这一点,设计了一个医院预约挂号平台,用来就预约的用户及医生进行管理,以便在最短的时间内,高效准确的完成整个预约过程。计算机技术在现代管理中的应用,使计算机成为领导者和管理人员应用现代技术的重要工具1。计算机辅助医院管理活动,可以极大地增强管理者采集、处理信息的能力,从而有利于管理者及时决策。计算机系统能根据管理过程的变化情况,将原始数据、资料等进行加工、保存,管理人员可以在解决具体问题需要信息资料时,随时进行检索查询,了解整个专家预约系统的动态情况,进行动态管理,从而有效的处理预约挂号的管理工作,实现医院预约管理的自动化,提高效率。(二)项目开发的目的通过使用本课题研究开发的系统,可以为用户到医院就诊提供高效、便捷的途径,解决传统医疗模式中人数过多所带来的诸多不便。使用户从传统的就医模式中解脱出来,特别是方便外地用户进行提前预约。解决传统医疗模式中的人工挂号对当前就诊情况反馈的不及时,导致对就诊人数控制不当的情况,使用户从漫长的挂号等待过程中解脱,从而提高医院整体的运作效率。用户对就医的时间的选择更有自主权,从而使其在医院内的停留时间大大缩短,减少大量用户长时间停留在候诊大厅加大院内感染的可能性。通过实名制挂号,杜绝挂号的“倒号”行为。促进医院数字医疗系统的快速发展。预约挂号系统能够统计门诊用户的各种数据,为数字医疗各系统提供准确、及时的用户信息,同时也可为医院的科研、管理活动提供相应的依据。二、可行性分析及总体设计原则(一)可行性分析可行性分析也称为可行性研究,是在调查的基础上,针对新系统的开发是否具备必要性和可能性,对新系统的开发从技术、经济、社会等方面进行分析和研究,以避免投资失误,保证新系统的开发成功2。可行性研究的目的就是用最小的代价在尽可能短的时间内确定问题是否能够解决。下面将分别从技术、经济、社会三个方面对医院预约挂号平台的建设进行分析和研究。1技术可行性根据医院医院提出的系统功能、性能及实现系统的各种约束条件,根据新系统目标来衡量所需的技术是否具备,本系统是一个数据库管理和查询的系统,现有的技术已较为成熟,硬件、软件的性能要求、环境条件等各项条件良好,估计利用现有技术条件应完全可以达到该系统的功能目标。同时,考虑给予的开发期限也较为充裕,预计系统是可以在规定期限内完成开发的。由以上分析可知,医院预约挂号平台的开发在技术上是可行的。2经济可行性医院具有信息化的处理设施,并且拥有支持本系统的应用平台。因此无需再投入资金购买其他设施。系统的开发基于本人对程序开发的实践学习而来,学校无需资金投入,并且软件开发过程投入的成本不高,因此开发经费完全可以接受。由以上分析可知,医院预约挂号平台在经济上是可行的。3社会可行性本系统的社会可行性主要从法律因素、用户使用可行性两方面进行研究。(1)法律因素本系统是根据医院预约管理的实际工作情况开发研制的,是通过大量的调研得出的,系统的软件设计是在独立的环境下完成的,无可供抄袭的软件产品。(2)用户使用可行性本系统对用户的要求,除了需要具备在Microsoft Windows平台上使用个人电脑的知识外,并不需要特别的技术能力。使用系统的管理员,需要具备对Tomcat服务器的使用能力,在投入使用前,无需对操作系统的人员进行培训。这样既减少投入成本又简化了操作环节。由以上分析可知,医院预约挂号平台具有社会可行性。(二)总体设计原则本系统为了设计、实现和后期维护的方便,以及系统用户使用的便利,所以必须采取一定的设计原则3。其主要设计原则有:简单性:在实现系统的功能的同时,尽量让系统操作简单易懂,这对于一个系统来说是非常重要的。针对性:本系统设计是针对医院预约挂号的需求定向开发设计,所以具有专业突出和很强的针对性。实用性:要求本系统能够满足专家、管理员及用户的需要,因此具有良好的实用性。一致性:页面整体设计风格以及命名规则的一致性:整体页面布局和用图用色风格及变量、类名和其他元素的命名规则保持一致。功能一致性:完成同样的功能应该尽量使用同样的元素。 元素风格一致性:界面元素的美观风格、摆放位置在同一个界面和不同界面之间都应该是一致的。变量命名规则的一致性:变量应该用统一的规则进行命名,做到任意变量均能从上下文推断其义。先进性:本系统采用JSP技术、SQL Server2000等被广泛采用系统开发技术和数据库,因此本设计具有良好的先进性,具体表现在其具有良好的可扩展性,可开发性。三、系统分析(一)业务流程分析在进行业务流程分析时,需要按照原有信息流动过程,逐个地调查分析所有环节的处理业务、处理内容、处理顺序和对处理时间的要求,弄清各个环节需要的信息、信息来源、流经去向、处理方法、计算方法、提供信息的时间和信息形态(报告、报单、屏幕显示)等4。业务流程分析可以帮助开发者了解该业务处理过程,发现和处理系统调查工作中的错误和疏漏。业务流程分析是通过业务流程图来进行,即用一些规定的符号及连线来表示某个具体业务处理过程5。具体业务流程如图3.1所示。图3.1业务流程图(二)数据流图数据流程是指数据在系统中产生、传输、加工处理、使用、存储的过程6。数据流程分析是把数据在现行系统内部的流动抽象的独立起来,舍去了具体组织机构、信息载体、处理工具、物质、材料等,单从数据流动过程来考查实际业务的数据处理模式。数据流程与数据流程分析是今后建立数据库系统和设计功能模块处理过程的基础。描述数据流程的工具是数据流程图以及其附带的数据字典、处理逻辑等图表。其中数据流程图是描述系统逻辑模型的主要工具,它以少数几种符号综合地反映出信息在系统中的流动、存储和传递7。在业务流程分析的基础上,对数据流进行了分析,从数据流动过程考察了实际业务的数据处理模式。该系统的数据流图分为顶层、一层、二层。现行的顶层数据流图如图3.2所示。图3.2顶层数据流图具体分析第一层数据流图,该层数据流图如图3. 3所示。图3.3第一层数据流图图3.4 P5展开数据流图由于论文的篇幅限制不能一一列举数据流图,其他的数据流图绘制方法基本一致。(三)数据字典通过对系统数据流的分析,接下来用数据字典描述数据流图中一些主要的数据元素条目、数据流、处理过程、数据存储和外部实体8。数据元素条目如表3.1所示。表3.1数据元素用户编号调入年份数据元素条目总编号:1-101编号:101名称:用户编号 XXX说明:用户的编号 数据值类型:离散长度:50有关数据结构:用户信息表如:123数据结构条目如表3.2所示。表3.2数据结构数据结构条目名称:用户信息表说明:创建用户信息记录似的数据总编号:2-01结构:编号:01医生编号有关数据流、数据存储:姓名P1用户管理、D1用户信息存储学历 数量:每周约300份职称科室年龄电话数据流条目如表3.3所示:表3.3数据流数据流条目名称:用户预约医生总编号:3-10说明:将预约信息存储到预约信息存储中编号:10数据流来源:P3预约管理数据流去向:D3预约信息存储 流通量:100份/周包含的数据结构:预约信息数据存储条目如表3.4所示:表3.4数据存储数据存储条目名称:预约信息存储总编号:4-01说明:存储预约信息 标号:D3结构:预约编号用户编号医生编号病情描述预约时间有关的数据流:P3D3 信息量:200份/周D3P1.2处理过程条目如表3.5所示:表3.5处理过程处理过程条目名称:预约管理总编号:5-15说明:用户预约医生管理。 编号:P3输入:P3预约管理输出:D3预约信息存储处理:将P3处理后的预约信息存储到预约存储中。外部实体条目如表3.6所示:表3.6外部实体外部实体条目名称:管理员总编号:6-01说明:管理系统的人员编号:001输入数据流: 个数:1个输出数据流:由于论文篇幅的限制,不在此一一列举,其他所有的数据字典条目都是根据数据流图绘制的。四、系统设计(一)系统功能设计系统设计是一个把软件需求转换成用软件系统表示的过程9。通过对目标系统的分析和研究,做出了对医院预约挂号平台的总体规划,这是全面开发系统的重要基础。在对医院预约挂号平台全面分析调查的基础上,制定出医院系统的总体规划。系统设计包括系统总体设计、系统详细设计、系统数据库设计、系统开发工具、开发技术和开发模式等。从数据流图出发,对数据流图进行分析,得出的层次化的模块结构图.医院预约挂号平台前台功能模块图如图4.1所示:图4.1功能模块图(二)系统数据库设计数据库是本系统的核心和基础10。它设计的好坏直接影响着整个系统的质量。数据是一切系统设计的基础,通俗地说,数据库设计就像高楼大厦的根基一样,如果设计的不合理、不完善,将在系统开发过程中,甚至到后期的系统维护、功能变更和功能扩充时,引起较多问题,严重时甚至要重新设计,重做大量已完成工作。1概念结构设计从数据需求分析中得出系统的实体属性图。医生实体属性图如图4.2所示:图4.2医生实体属性图管理员实体属性图如图4.3所示:图4.3管理员实体属性图科室实体属性图如图4.4所示:图4.4成绩实体属性图用户实体属性图如图4.5所示:图4.5用户实体属性图预约实体属性图如图4.6所示:图4.6预约实体属性图E-R模型的组成元素有:实体、属性、联系。E-R模型用E-R图表示。实体是用户工作环境中所涉及的事务,属性是对实体特征的描述11。(1)模型中的实体相当于实体集、一个表,而不是单个实体或表中的一行。实体用矩形框表示,实体名称标注在矩形框内。用菱形表示实体间的联系,菱形框内写上联系名,用无向边把菱形分别与有关实体相连接,在无向边旁标上联系的类型12。(2)属性是实体的性质。用椭圆框表示,与实体之间用一条线相连表的主码是关键属性,关键属性项加下划线。(3)各子系统模块中主键相同的字段之间存在着相互关联的关系。(4)在程序中实现对他们的完整性和一致性控制。从数据需求分析中得出系统的实体属性图,遵循三范式原则,对实体之间的依赖关系进行了整合,得出系统E-R图,如图4.11所示:图4.11系统E-R图说明:图中用矩形表示实体。实体之间的关系用菱形表示,用无向边把菱形与有关实体连接,在边上标明联系的类型。实体的属性用椭圆表示,并用无向边把实体与属性联系起来。2逻辑结构设计对数据库中实现具体表的详细设计。即各数据库表的字段名、类型、长度等信息进行了详细的描述根据系统E-R图,系统数据逻辑结构设计如下:1)医生(医生编号,姓名,学历,职称,可预约人数,时间,所属科室编号,已预约人数)2)科室(科室编号,科室名称)3)用户(用户编号,姓名,用户名,密码,年龄,电话,性别,病情描述)4)预约(预约编号,预约时间,病情描述,科室编号,医生编号,预约状态,备注)5)管理员(管理员编号,用户名,密码)3数据库表设计表4.1管理员信息表字段名类型长度说明idInt4管理员编号(主键)namevarchar30用户名pwdvarchar20用户密码说明:用户表用于存放管理员的信息。表4.2医生信息表字段名类型长度说明idInt4医生编号(主键)namevarchar30医生姓名timedatetime8时间grxlvarchar50医生学历zhicvarchar50职称renshuInt4可预约人数renshu1Int4已预约人数hosDepartIdInt4科室编号(外键)说明:用于存放医生的基本信息。表4.3科室信息表字段名类型长度说明idInt4科室编号(主键)namevarchar20科室名称说明:用来存放科室的基本信息。表4.4用户信息表字段名数据类型长度功能描述idInt4用户编号(主键)namevarchar20用户名pwdvarchar20密码truenamevarchar20姓名ageInt4年龄telephonevarchar30电话sexvarchar10性别describevarchar100病情描述说明:用来存放用户的基本信息。表4.5预约信息表字段名数据类型长度功能描述idInt4预约编号(主键)timedatetime8时间describevarchar100病情描述didInt4科室编号DocIDInt4医生编号statevarchar10状态beizhuvarchar100备注说明:用来存放预约的基本信息的。(三)系统开发工具与开发模式的选择1系统开发工具本系统主要使用JSP、Struts技术对系统进行设计和开发。JSP拥有Java程序设计语言“一次编写,各处执行”、“安全性、保密性高”等的特点13;Struts框架为开放者提供了一个统一的标准框架,通过使用Struts作为基础,开发者能够更专注于应用程序的商业逻辑,Struts能充分满足应用开发的需求,简单易用,敏捷迅速。使用Microsoft SQL Server 2000数据库作为后台数据库,SQL Server 2000系统具有强大的网上功能,可以在互联网上发布数据库中的数据。在SQL Server 2000系统中,允许用户简单的使用一些向导和工具把数据库的数据发布到网络上,并且可以根据需要来调度修改已经发布的数据。在大家所了解数据库系统中,Microsoft SQL Server 2000,经过三十多年的发展,已经成为最重要的数据处理技术,被广泛应用到多种项目的开发与设计中,决定采用此数据库系统来完成系统的设计。2系统设计模式目前,在大多数B/S(Browser/Server)结构的Web应用中,浏览器直接通过HTML或者JSP的形式与用户交互,响应用户的请求。虽然很直观,但是大多数管理信息系统操作的数据量都是惊人的,随着代码的增多会使JSP页面臃肿不堪,Web服务器的负荷过重。因此,在中间层上采用基于模型视图控制器(MVC,Model-View-Controller)的设计模式。Model层用来实现业务逻辑,View层用来显示用户界面,Controller层主要负责View层和Model层之间的控制关系。具体实现时,把Servlet用作应用程序的控制器,把JSP文档作为视图,JavaBeans被用来表示模型。所有的请求都被发送给作为控制器的Servlet,它接受请求,并根据请求信息将它们分发给适当的JSP来响应。同时,Servlet还根据JSP的需求生成JavaBeans的实例并输出给JSP环境。JSP可以通过直接调用方法或使用UseBean的自定义标签得到JavaBeans中的数据。这种设计模式很好地实现了数据层与表示层的分离,使开发工作更加容易和迅速。五、系统实现(一)用户模块1登录及注册管理模块(1)登录模块此模块主要功能是用于登录本系统,不同权限的用户登录本系统会进入不同的管理模块界面,因为在后台对该用户进行的判断,首先将从前台页面提交的用户名和密码进行接受,之后在后台进行处理,按照用户名在数据库中进行查询如果查到该用户则将该用户的权限和密码全都取出来分别赋给两个字符串变量,判断从数据库中读出的密码与登录时输入的密码是否配比上,若两个密码相同则根据权限的值进入相应的页面,否则输出密码错误。若用户未被管理员分配好权限那么也是无法登录本系统的。如图5.1所示:图5.1 前台登录界面<table cellspacing="0" cellpadding="0" width="98%" align="center" border="0"> <tr> <td align="center" colspan="2" height="10"></td> </tr> <tr> <td align="right" width="31%" height="30" style="font-size: 11px;">用户名:</td> <td align="left" width="69%"><input class="input" id="userName" title="用户名不能为空" size="14" name="userName" type="text" /></td> </tr> <tr> <td align="right" height="30" style="font-size: 11px;">密码:</td> <td align="left"><input class="input" title="密码不能为空" type="password" size="16" name="userPw"/></td> </tr> <tr> <td align="center" colspan="2" height="10"><font color="red"><s:property value="#request.error"/></font></td> </tr> <tr> <td align="center" colspan="2" height="30"> <input type="button" value="登 录" onclick="login()" style="border:#ccc 1px solid; background-color:#FFFFFF; font-size:12px; padding-top:3px;" /> <input type="button" value="注 册" onclick="reg()" style="border:#ccc 1px solid; background-color:#FFFFFF; font-size:12px; padding-top:3px;" /> </td> </tr> </table>(2)程序流程图5.2登录程序流程图2首界面用户登陆在输入正确的用户名和密码后,就可以登陆本系统。如图5.3所示:图5.3首界面String sql="from TAdmin where userName=? and userPw=?"Object con=userName,userPw;List adminList=adminDAO.getHibernateTemplate().find(sql,con);if(adminList.size()=0) result="no"else WebContext ctx = WebContextFactory.get(); HttpSession session=ctx.getSession(); TAdmin admin=(TAdmin)adminList.get(0); session.setAttribute("userType", 0); session.setAttribute("admin", admin); result="yes"3用户注册界面用户必须注册本系统后才可以预约。如图5.4所示:图5.4用户注册界面<table width="98%" border="0" align="center" cellpadding="0" cellspacing="1" bgcolor="#CCCCCC"><tr><th height="40" colspan="2" bgcolor="#FFFFFF" class="f12b-red" style="font-size: 11px;">用 户 注 册</th></tr><tr><td width="20%" height="30" align="right" bgcolor="#F9F9F9" style="font-size: 11px;">用户名:</td><td width="80%" bgcolor="#FFFFFF"> <input type="text" name="userName" id="userName"/></td></tr><tr><td height="30" align="right" bgcolor="#F9F9F9" style="font-size: 11px;">密 码:</td><td bgcolor="#FFFFFF"> <input type="password" name="userPw"/></td></tr><tr><td height="30" align="right" bgcolor="#F9F9F9" style="font-size: 11px;">密码确认:</td><td bgcolor="#FFFFFF"> <input type="password" name="userPw1"/></td></tr><tr><td height="30" align="right" bgcolor="#F9F9F9" style="font-size: 11px;">真实姓名:</td><td bgcolor="#FFFFFF"> <input type="text" name="userRealname"/></td></tr><tr><td height="30" align="right" bgcolor="#F9F9F9" style="font-size: 11px;">住址:</td><td bgcolor="#FFFFFF"> <input type="text" name="userAddress"/></td></tr><tr><td height="30" align="right" bgcolor="#F9F9F9" style="font-size: 11px;">性别:</td><td bgcolor="#FFFFFF"> <input type="radio" name="userSex" value="男" checked="checked"/>男 <input type="radio" name="userSex" value="女"/>女</td></tr><tr><td height="30" align="right" bgcolor="#F9F9F9" style="font-size: 11px;">联系方式:</td><td bgcolor="#FFFFFF"> <input type="text"