医院门诊管理系统(27页).docx
-医院门诊管理系统-第 23 页目 录1 引 言51.1 门诊管理系统概述51.2 本课题研究的背景及意义51.2.1 研究本课题的背景51.2.2 研究本课题的意义51.3 本课题研究的内容52 系统开发技术及开发环境介绍62.1 JSP概述62.2 JAVA语言概述62.3 MYSQL概述62.4 系统开发和运行环境63 系统分析73.1 需求分析73.2 可行性分析74 系统设计74.1 系统目标74.2 系统流程图74.3 系统功能结构84.3.1门诊管理系统功能结构图85 数据库设计95.1 数据库需求分析95.2 数据库概念设计95.3 数据库逻辑结构设计126 系统功能实现136.1后台功能模块设计136.1.1门诊工作人员登录模块136.1.2挂号收费管理模块146.1.3病人信息管理模块186.1.4药品信息管理模块216.1.5病历信息管理模块256.1.6划价收费管理模块306.1.7科室信息管理模块307结 论34参考文献35致谢36医院门诊管理系统摘 要 在以前我国大多数医院都采用人工管理的方法来完成医院门诊管理中的各个步骤,这样的管理方式效率低,出错率高。随着计算机科学技术的飞速发展,医院门诊管理系统的应用在全球范围内日益普及。在当代的医院门诊管理中,人们逐渐开始意识到信息系统对医院的促进作用。逐步建立数字化的医院门诊管理系统来管理医院的各个工作流程。本设计采用了B/S构架开发设计的一个医院门诊管理系统,此系统在功能上可基本实现医院系统的应用。系统设计开发视图界面和数据库设计,分析了医院门诊系统的功能,并根据用户需求,使用jsp+servlet+javabean的开发模式,基本实现此系统的各功能。 关键字 B/S构架;医院门诊;管理系统Hospital Outpatient Management SystemAbstract: In the past, most hospitals in our country have adopted the methods of artificial management to complete the various steps in the hospital outpatient management, which is inefficient and the error rate is high. With the rapid development of computer science and technology, the application of hospital outpatient management system is becoming more and more popular in the world. In the modern hospital outpatient management, people gradually began to realize the role of information system to the hospital. Gradually establish a digital hospital outpatient management system to manage all the work flow of the hospital. This design uses the B/S framework development and design of a hospital outpatient management system, this system can basically realize the function of the hospital system. System design and development view interface and database design, analysis of the hospital outpatient system functions, and according to user needs, the use of jsp+servlet+javabean development model, the basic realization of the various functions of the system.Key Words: B/S framework,Hospital clinic,Management system1 引言随着社会的不断发展和科技的不断进步,作为21世纪重要标志的计算机也蓬勃发展起来,人们对各行各业的服务要求也越来越高。进入21世纪后,国家的医疗制度的日益完善,过去的手工开单就诊流程已经不能满足人们的需要。现在几乎所有的医院都利用计算机信息管理技术的手段来代替人工作业,从而减少人员工作量,减轻工作负担,减少工作中人为原因产生的错误而带来的不必要的损失。提高医疗门诊部门服务效率和服务质量。为了实现医院门诊信息化的建设,加快医院系统的信息化步伐,提高提高医院的服务水平,完善医院信息已经变得十分重要。系统的建设本着“以患者为中心”的原则,以方便患者、提高就诊效率,为患者提高满意的服务,提高医院的社会效益和经济效益。本课题对医院信息系统的现状进行分析,简单介绍了所选课题背景,系统主要运用了标准的MVC三层架构(jsp+servlet+javaBean)的技术,以JSP作为前台开发环境,以JavaBean作为业务逻辑,实现门诊管理系统增删改查的功能,医院门诊部门工作人员以不同的身份登录系统,挂号部门能够将病人的信息录入,通过病人的要求描述选择医生和科室。医生能够将病人的病例信息输入系统。通过医生所开处方进行划价收费。1.1门诊管理系统概述医院门诊管理系统是根据医疗机构特定的流程而开发的,包括门诊部门工作人员的登录、挂号管理、病历管理、科室管理、划价收费管理等。为医院管理提供有力的保障。门诊管理系统提供了全面人性化的服务体系,其目的在于实现医疗门诊的自动化,现在市场的竞争越来越大,只有提高医疗质量,才能够满足更多病人的需求和医疗管理的需求。从而促进医院的发展。1.2 本课题研究的背景及意义1.2.1 研究本课题的背景在过去相当长的一段社会实践生活中,人们总是及时地利用刚刚出现的新工具和新技术来改进交流方法和生活以及生产方式,因此层出不穷换出新的工业革命。如今计算机信息技术正在以更大范围及空间、更加快速地改变着人们的生活,总体来说计算机信息技术发展虽然只有短短几年的时间,但以其快速而稳健的发展步伐逐渐取缔了传统的市场,如今研究它的相关的技术已经达到了炉火纯青的地步,计算机信息技术在人们生活中的地位已经根深蒂固,成为了21世纪的新标志。随着我国医疗卫生体制的改革,计算机信息管理已经成为各个医院提高竞争力,提高医疗管理力度,提高经济效益的重要保障。目前在全国各大医院的管理上,多数使用传统的管理方式,这样很大程度上降低了医院门诊工作人员的工作效率且录入数据准确性不高,不能很好的对数据进行统计。但是延伸到生活的各个领域,在这样的环境背景下,设计出一款适用于医院门诊管理人员使用的系统,这样一来科大大提高医务人员的工作效率。1.2.2 研究本课题的意义当前,电脑差不多普及家家户户,计算机信息技术已经成为人类生活的一种方式5中国的计算机信息技术的萌芽期已经结束, 现在已经进入了发展时期。新一代的计算机信息技术能够吧信息采集存储处理,使用信息技术的医院已超过上万家,对门诊管理系统需求医院越来越多,这一趋势带动了电子科技公司企业的不断研发。医院门诊管理系统的新模式。6如今各个医院门诊的为了增强竞争力和医疗管理,对医院门诊系统的需求原来越多,要求也越来越高。因此,不断地研发改进这平台将对门诊管理系统的发展和完善有着深刻的意义。1.3 本课题研究的内容本课题主要内容是设计医院门诊管理系统,该系统采用Java Web工程开发技术,在Windows平台上使用,开发工具为MyEclipse10,服务器为Tomcat7.0,数据库采用MYSQL,使用JSP开发视图页面和Servlet进行流程控制,使用JDBC编写工具类对数据库进行访问,分析功能写具体实体类的Dao,分析业务写Service。使用Filter实现用户权限功能,过滤掉该用户去权限的URL,确保医院门诊系统各个功能模块的正确。2 系统开发技术及开发环境介绍2.1 JSP概述JSP是由sun公司倡导、许多公司参与一起研发的一种动态网页技术标准语言,通俗的理解就是用来表达或者显示动态的值的HTM页面。2JSP的本质是servlet,它是Servlet的实例,是为了方便开发人员能够以编辑HTML的方式来写Servelt。JSP既有java代码又有HTML标签,而Servlet只是纯粹的java代码。7JSP文件保存在Tomcat服务器中,当JSP文件被第一次请求时,Tomcat服务器将JSP文件转义为java文件,然后再将java文件翻译成字节码文件,最后字节码文件才响应客户端的请求。92.2 JAVA语言概述JAVA是由sun公司推出的一种程序设计语言。Java语言是一种面向对象、可以跨平台的语言。8JAVA技术具有卓越的通用性、高效性、平台移植性和安全性,广泛应用于应急系统、政府办公系统、游戏控制台、移动通信、互联网等等。JAVA语言具有封装、继承、多态三大特称。1封装就是通过定义类然后给这个类的属性和方法加上访问控制,继承就是代码的重用,多态就是一个方法只能有一个名词,但可以有很多种形态。2.3 MYSQL概述MYSQL是瑞典MYSQL AB 公司研发出的一种数据库管理系统。在2008年被SUN公司收购,到2009年SUN又被Oracel收购。3MYSQL体积很小,但是运行的速度比较快,总体拥有的成本也比较低,MYSQL被广泛应用在很多中小型的网站中。MYSQL是基于客户端/服务器模式的数据库系统,通过图形化界面用户可以方便而快捷的对数据库进行管理,它还提供较为丰富的编程接口,给编程的开发设计提供了很多的便利。2.4 系统开发运行环境系统开发运行环境如下:1.硬件(1) CPU Inter core i5: (2)内存: 2G (3)足够的可用硬盘空间:(4)显示: 1024*7682.软件(1)操作系统: windows 7(2) Web服务器(3)浏览器, IE7.0以上;(4)数据库MYSQL(5)开发工具 MyEclipse103 系统分析3.1 需求分析对本系统要求有以下功能:一、医院门诊部门工作人员以不同的身份登录系统。系统能够长期稳定的运行、数据库的访问权限设置合理,保证用户账号信息安全。二、挂号部门能够将病人的信息录入,通过病人的要求描述选择医生和科室。系统要极易进行维护,相关的数据要及时更新并且数据不能出现错误。10三、医生能将病人的病例信息输入系统,操作要简单明了,层次分明。四、通过医生所开处方进行划价收费3.2 可行性分析随着信息时代的到来,医院门诊管理系统成为了医院对医疗流程的工具、在医院门诊管理系统中,工作人员登录进入系统后,可以进行挂号录入,添加病人信息,查看病人信息,划价收费等操作。4如挂号部门根据病人的描述对病人选择医生和科室,医生经过对病人诊断后,对病人的基本信息进行增加、删除、修改和查询,看完医生后病人到指定的药品窗口买药,收费人员对病人所拿的据单进行查询和统计然后收取费用。4 系统设计4.1 系统目标对于目前竞争日趋激烈的医疗机构,民营医院逐渐进入市场,医疗机构的管理系统愈发凸显其重要性,医院门诊管理系一定要满足使用操作方便灵活等设计要求,因此,设计需满足这几个目标:一、所有的操作步骤要简单易懂、系统的相关界面设计要清洁美观。二、医院门诊部门工作人员以不同的身份登录系统。三、挂号部门能够将病人的信息录入,通过病人的要求描述选择医生和科室。四、医生能将病人的病例信息录入系统。五、通过医生所开处方进行划价收费。4.2 系统流程图医院门诊系统流程图工作人员登录病例管理模块划价收费模块挂号收费模块选择科室及挂号类型查看该医生姓名、科室、职称及挂号费价格挂号收费凭证打印输入病例本编号或病人姓名查看病人信息或对病人信息进行录入输入药品名、选择药品规格、输入药品数量查看药品名称、规格、数量、药单价及总价划价或收费凭证打印退出 4.3 系统功能结构4.3.1门诊管理系统功能设计医院门诊管理系统病历管理科室管理划价管理挂号管理工作人员管理工作人员退出药品信息管理药品收费信息科室信息删除科室信息修改挂号服务功能病人信息管理信息咨询科室信息添加科室信息查询病历删除功能病历修改功能病历查询功能病历信息录入工作人员登录药品信息删除药品信息修改药品信息添加5 数据库设计5.1 数据库需求分析 数据库在设计结构上能够充分的考虑到各种信息的输入和输出,通过数据字典能够清楚地知道数据结构和处理的过程,为后面的详细设计打下基础,经过总结得出以下几点需求信息:1、系统需要设计为前后台;2、门诊部门工作人员可以不同的身份登录系统,比如医生登录、收费人员登录、挂号人员登录等;3、一个用户可以购买多种商品;4、在线留言功能;5、要分别统计销售情况; 5.2 数据库概念设计 通过对门诊管理系统进行相关需求分析后,得出使用数据实体分别为:“病历信息”、“医生信息”、“药品信息”、“病人信息”、“挂号信息”、“科室信息”。各实体E-R图如下:(1) 病历信息的E-R图病人姓名诊断结果诊断方法用户编号处方编号诊断时间病历信息就诊卡号病历编号(2)医生信息E-R图医生编号医生详情医生所在科室医生姓名医生信息医生状态医生性别医生年龄(3)药品信息E-R图药品功能药品规格生产厂家药品编号 药品药品有效期药品名称药品库存药品单价(4)病人信息E-R图病人年龄病人病人性别病人姓名就诊卡号(5)挂号信息E-R图挂号类型挂号编号挂号挂号日期挂号费用科室编号就诊卡号(6)科室E-R图科室 科室编号科室名称5.3 数据库逻辑结构设计完成的E-R图的设计之后,还需要设计数据表结构,以下是医院门诊管理系统中的数据表结构。1.t_userinfos(工作人员信息表)表t_userinfos用于保存门诊工作人员的基本信息列 名数据类型允许空字段说明u_idvarchar(30)否工作人员编号u_namevarchar(30)是工作人员姓名u_pwdvarchar(20)是工作人员密码u_sexvarchar(10)是工作人员性别u_agevarchar(20)是工作人员年龄u_telvarchar(100)是工作人员电话u_emailvarchar(50)是工作人员邮箱u_titlevarchar(50)是工作人员职称u_taskstatevarchar(20)是工作人员状态u_expvarchar(100)是工作人员描述2. t_patients(病人信息表) 表t_patients,记录患者的个人信息列 名数据类型允许空字段说明pi_idvarchar(20)否病人编号Pi_namevarchar(30)否病人姓名pi_sexvarchar(10)否病人性别pi_agevarchar(20)否病人年龄3. t_case(病历表)记录病人的就诊信息 列 名数据类型允许空字段说明c_idvarchar(20)否病历编号c_datevarchar(50)否诊断时间c_resultvarchar(50)否诊断结果c_methodvarchar(50)否诊断方法pi_idvarchar(20)否就诊卡号pi_namevarchar(20)否病人姓名rc_idvarchar(20)否处方编号u_idvarchar(20)否工作人员编号4. t_doctor(医生表)记录医生的基本信息列 名数据类型允许空字段说明d_idvarchar(20)否医生编号d_namevarchar(20)否医生姓名d_sexvarchar(10)否医生性别d_agevarchar(20)否医生年龄d_statevarchar(30)是医生状态d_detailvarchar(30)是医生详细信息d_telvarchar(50)是医生电话S_idvarchar(20)否医生所在的科室5. t_medicine(药品表)记录药品详细信息, 列 名数据类型允许空字段说明m_idvarchar(20)否药品编号m_namevarchar(20)否订单编号m_specvarchar(20)否药品规格m_countvarchar(20)否药品库存m_funtionvarchar(50)否药品功能m_pricevarchar(20)是药品单价m_timevarchar(20)否药品有效期m_addrvarchar(50)否生产厂家6. t_section(科室表)记录科室的基本信息列 名数据类型允许空字段说明s_idvarchar(20)否科室编号s_namevarchar(30)否科室名称 7. t_registration(挂号表) 记录挂号的基本信息列 名数据类型允许空字段说明rg_idvarchar(20)否挂号编号rg_pricevarchar(20)否挂号费用rg_typevarchar(50)否挂号类型rg_datevarchar(50)否挂号日期s_idvarchar(20)否科室编号pi_idvarchar(20)否就诊卡号6 系统功能实现6.1功能模块设计6.1.1登录模块医院门诊工作人员或系统管理员通过登录页面输入自己的账号和密码,在LoginServlet控制器接收输入的账号和密码,调用Dao层和业务层Service,然后判断在系统中是否已经存在该用户,如果已经存在就提示登录成功,跳转到主页面,若不存在,则提示登录失败,跳转回登录页面,再重新登录。登录的页面设计如下图:登录页面login.html前端页面代码: 用户<input type="text" name="u_id" id="textfiel">密码<input type="password" name="u_pwd" id="textfield2">验证码<input type="text" name="u_code" id="textfield3">前端页面提交数据到LonginServlet控制器代码:public void doPost(HttpServletRequest request, HttpServletResponse response)throws ServletException, IOException String u_id = request.getParameter("u_id"); String u_pwd = request.getParameter("u_pwd"); String u_code = request.getParameter("u_code");String verifyCode = (String) request.getSession().getAttribute("verifyCode");public boolean login(UserInfo userInfo) String sql = "select * from T_userInfos where u_id='"+ userInfo.getU_id() + "' and u_pwd='" + userInfo.getU_pwd()+ "'"return userInfoDao.login(sql);boolean flag = userInfoService.login(userInfo); if (flag) if (u_code.equals(verifyCode) / 保存账户名到session中request.getSession().setAttribute("u_id", u_id);out.print(" alert("恭喜您登录成功!");"); else out.print(" alert("验证码输入有误,请重新登录!");");out.print("window.location.href="html/login.htm"" else out.print(" alert("帐户名或密码有误,请重新登录!");");out.print("window.location.href="html/login.htm"");return;6.1.2挂号收费管理模块医院门诊工作人员为前来挂号看病的患者,提供挂号服务。医院门诊人员可根据患者的描述,选择科室,查看当前值班医生,可以向需要的患者提供必要的医生详细并进行挂号,并打印挂号凭证。可以对前来咨询医生工作时间或医院药品情况的就诊人员提供必要的咨询服务。挂号收费管理模块的设计如图所示:挂号收费管理挂号信息的录入如下图:挂号信息的修改如下图:挂号录入(添加)代码:public void doPost(HttpServletRequest request, HttpServletResponse response)throws ServletException, IOException / 获取操作对象optString opt = request.getParameter("opt");/ 病人信息IPatientService patientService = new PatientServiceImpl();Patient patient = null;/ 挂号信息IRegistrationService registrationService = new RegistrationServiceImpl();Registration registration = null;/ 获取挂号页面信息String rg_id = request.getParameter("rg_id");String s_id = request.getParameter("s_id");String pi_id = request.getParameter("pi_id");String rg_price = request.getParameter("rg_price");String rg_date = request.getParameter("rg_date");String rg_type = request.getParameter("rg_type");/ 病人信息String pi_name= request.getParameter("pi_name");String pi_sex=request.getParameter("pi_sex");String pi_age = request.getParameter("pi_age"); * 添加病人信息 * 添加挂号信息if ("add".equals(opt) patient = new Patient(pi_id,pi_name,pi_sex,pi_age);registration = new Registration(rg_id, s_id, pi_id, rg_price,rg_date, rg_type);try / 调用病人的添加patientService.addpatient(patient);/ 调用挂号的添加registrationService.addregistration(registration);response.sendRedirect("registration2.do?obj=queryAll"); catch (Exception e) e.printStackTrace();response.sendRedirect("error.html");return;删除挂号信息代码:if ("del".equals(opt) registration = new Registration(rg_id);try registrationService.delregistration(registration);response.sendRedirect("registration2.do?obj=queryAll"); catch (Exception e) e.prinStackTrace();response.sendRedirect("error.html");return;修改挂号信息代码:if ("upd".equals(opt) registration = new Registration(rg_id, s_id, pi_id, rg_price,rg_date, rg_type);try registrationService.updregistration(registration);response.sendRedirect("registration2.do?obj=queryAll"); catch (Exception e) e.printStackTrace();response.sendRedirect("error.html");return;查询所有的挂号信息列表相应代码:/ 分页String gopage = request.getParameter("goNumber");String obj=request.getParameter("obj");/ 获取操作对象if("queryAll".equals(obj)int goNumber = 0;if(gopage!=null&& !gopage.equals("")goNumber =Integer.parseInt(gopage);/将挂号的信息放入集合中 List<Registration2> list = new ArrayList<Registration2>();if(opt != null && !opt.equals("")list = (List<Registration2>) request.getSession().getAttribute("list");elseif(rg_id!=null && !rg_id.equals("") | pi_id!=null && !pi_id.equals("")registration2 = new Registration2();registration2.setRg_id(rg_id);registration2.setPi_id(pi_id);list = registrationService2.queryAll(registration2);/查询之后存入sessionrequest.getSession().setAttribute("list", list);/生成pager(第一页)pager = new Pager();if(gopage!=null)pager = new PagerService().getPager(goNumber, opt, list.size();elsepager = new PagerService().getPager(pager.getCurrentPage(), opt, list.size();List<Registration2> pageList = new ArrayList<Registration2>(); * 获取到list.size就可以进行分页for(int i = pager.getStartRow(); i < pager.getStartRow()+pager.getPageSize() && i < list.size(); i+)pageList.add(list.get(i);request.setAttribute("listA", pageList);request.setAttribute("pager", pager);request.getRequestDispatcher("html/media/showregistration2.jsp").forward(request, response);6.1.3病人信息管理模块医院门诊工作人员可以对病人的基本信息进行集中管理,对初诊病人进行录入基本信息,录入错误还可以对病人信息进行修改或者删除,还可以输入病人的就诊卡号或者姓名对病人的信息进行查询。病人信息以及信息的添加如图所示:病人信息管理对初诊人员进行基本信息录入,病人信息的添加如下图: 门诊工作人员根据需要对病人的错误信息进行修改。病人信息修改如下图:病人增删改查相应的代码:public void doPost(HttpServletRequest request, HttpServletResponse response)throws ServletException, IOException request.setCharacterEncoding("utf-8");response.setContentType("text/html;charset=utf-8");PrintWriter out = response.getWriter();/ 获取操作只是optString opt = request.getParameter("opt");/ 生成服务对象IPatientService patientService = new PatientServiceImpl();Patient patient = null;/ 获取页面信息String pi_id = request.getParameter("pi_id");String pi_name= request.getParameter("pi_name");String pi_sex=request.getParameter("pi_sex");String pi_age = request.getParameter("pi_age");String obj = request.getParameter("obj");String gopage = request.getParameter("goNumber"); * 添加病人信息if ("add".equals(opt) System.out.println("opt->" + opt);patient = new Patient(pi_id,pi_name,pi_sex,pi_age);try / 调用病人的添加patientService.addpatient(patient);response.sendRedirect("patient.do?obj=queryAll"); catch (Exception e) e.printStackTrace();response.sendRedirect("error.html");return; * 删除病人信息if ("del".equals(opt) patient = new Patient(pi_id);try patientService.delpatient(patient);response.sendRedirect("patient.do?obj=quer