Initial commit

This commit is contained in:
NTllNzNiN2E2 2021-10-19 07:31:04 +08:00
parent 63a12bd237
commit 6bb6a05dbb
5 changed files with 1010 additions and 2 deletions

806
README.md
View File

@ -1,3 +1,805 @@
# Private-dental-clinic-management-system
# 基于JSP和MySQL的私人牙科诊所管理系统
基于JSP和MySQL的私人牙科诊所管理系统
# 摘 要
随着科技的飞速发展计算机已经广泛的应用于各个领域之中。在医学领域中计算机主要应用于两个方面一是医疗设备智能化以硬件为主。另一种是病例信息管理系统HIS以软件建设为主以提高私人牙科诊所病例的现代化管理水平。本次毕业设计的主要任务是基于B/S模式开发设计一个私人牙科诊所病例管理系统以提高私人牙科诊所病例的现代化管理形象。该系统包括药品管理、挂号管理、开药管理和药房管理四个部分可以实现药品、患者的录入、删除、修改和查询等功能特别适应各大中小型私人牙科诊所病例提高私人牙科诊所病例管理水平系统设计合理操作简便。
本文采用面向对象分析的方法,详细阐述了一个功能比较强大的牙科诊所管理系统的前后台开发,操作流程和涉及的一些关键技术。首先进行了可行性分析,然后是面向对象分析,通过实际的业务流程需要,抽取和整理用户需求,建立了问题域精确模型;然后是面向对象设计阶段,主要是把分析阶段得到的对目标系统的需求转变成符合成本和质量要求的,抽象的系统实现方案,阐述了系统设计的思想,数据库的设计和系统设计的工具及技术。该阶段对本系统各个对象的属性和方法进行了详细设计,建立了本系统的对象模型,形成了本系统的类图;数据库设计时先进行了概念结构设计,然后进行了逻辑结构设计,最后完成了数据表的设计。
根据前几个阶段的分析和设计本系统在设计方面采用B/S模式同时使用JSP技术进行基本页面的设计与功能实现后台数据库选用MySQL数据库。本系统的设计实施为牙科诊所管理系统的运行做基础为牙科诊所管理系统工作提供良好的条件。
**关键词**牙科诊所病例门诊管理JSPB/S模式
# ABSTRACT
With the rapid development of science and technology, computers have been widely used in various fields. In the field of medicine, computers are mainly applied to two aspects: one is the intelligence of medical equipment and the hardware. The other is the case information management system (HIS), which focuses on software development to improve the level of modern management of cases in private dental clinics. The main task of this graduation design is based on B/S pattern development and design a private dental clinics case management system in order to improve the modern management image of the private dental clinic cases. The system includes drug management, register management, prescribe medicine and pharmacy management four parts, of drugs, patients can be accomplished by the input, delete, modify, and query, and other functions, especially for the small and medium-sized private dental clinic cases, improve the level of private dental clinics case management, reasonable system design is simple.
This article adopts the method of object-oriented analysis, elaborated the function of a more powerful Taiwan before and after the development of the dental clinic management system, operation process and some of the key technologies involved. First has carried on the feasibility analysis, then the object-oriented analysis, through the actual business process needs, extract and user needs, set up the precise model the problem domain; Then the object-oriented design phase, mainly with the analysis phase of the demand for the target system into conformity with the requirements of the cost and quality of abstract system implementation plan, expounds the ideas of system design, database design and system design tools and techniques. In this phase, the object model of the system is set up, and the class diagram of the system is formed. The design of the conceptual structure was carried out first, then the logical structure design was carried out, and the design of the data table was completed.
According to former several stages of the analysis and design, this system adopts B/S mode in terms of design, and using JSP technology of basic pages design and function implementation of background database choose MySQL database. The design of this system is implemented as the basis for the operation of the dental clinic management system, and provides good conditions for the operation of the dental clinic management system.
**Key words**: the patient outpatient clinic administration; JSP; B/S pattern
# 1.引言
私人牙科诊所病例信息系统HOSPITAL INFORMATION SYSTEM简称HIS是私人牙科诊所病例实现现代化建设的重要基础工程是提高私人牙科诊所病例管理水平、医疗水平、业务运转效率和服务质量的必要手段是指应用电子计算机和网络通信设备对私人牙科诊所病例的病人医疗信息、财务核算分析信息、预约信息进行收集、存储、处理、提取和数据通讯满足所有授权用户对信息使用需求的计算机应用软件系统。
## 1.1 项目开发的背景
随着计算机产业的迅速发展,电子计算机已广泛的应用于信息管理,文字处理,辅助设计,辅助教学及人们的日常生活中。牙科诊所管理系统主要针对各医院门诊管理的一系列相关工作的管理,本系统的建立使得牙科诊所的管理更加规范化,系统化,查询手段更加便捷化。同时,本系统采用面向对象的开发方法,进一步解决了结构化范性存在的软件重用程度低,软件产品难以维护的问题。
近年来,随着就诊的病人的数量的逐渐增加,人工书写数据已经不能够处理如此庞大的数据。为了更好的适应信息时代的高效性,一个利用计算机来实现牙科诊所管理系统工作的系统必然诞生。基于这一点,所设计的牙科诊所管理系统用来就诊所进行管理,以便在最短时间内,高效准确的完成整个管理过程。
基于上述认识,收集相关资料和数据,查阅有关文献及技术参数,对用户需求进行调研,发现目前所采用的手工记录的方法进行管理存在对象范围广,数据存储不易,不易存档,成千上万的信息和堆积如山的单据对管理人员来说是个负担,需要大量的文档资料。而已经存在的一些面向过程设计的诊所管理系统软件重用程度低,软件产品不易维护。鉴于上述种种原因,牙科诊所管理急需一种面向对象的设计的软件来管理数据资料。
计算机技术在现代管理中的应用,使计算机成为领导者和管理人员应用现代技术的重要工具。计算机辅助门诊管理活动,可以极大地增强管理者采集,处理信息的能力,从而有利于管理者及时决策。计算机系统能根据管理过程的变化情况,将原始数据,资料等进行加工,保存,管理人员可以在解决具体问题需要信息资料时,随时进行检索查询,了解整个牙科门诊管理系统的动态情况,进行动态管理,从而有效的处理牙科门诊的管理工作,实现牙科诊所管理的自动化,提高效率。
## 1.2 项目开发的目的
牙科诊所管理系统的开发目的是使得牙科诊所管理系统模式从手工记录转变成信息管理,从面向过程开发的软件转变成面向对象开发的软件,为门诊管理人员提供方便,为软件维护工作人员提供方便。对用户的实际情况进行调研,进行详细的需求分析,对现有的管理模式进行改进,开发出一套新型的面向对象的管理系统,从中领悟系统开发的思想,掌握系统开发的流程和方法。随着门诊信息系统的不断完善,医院的管理将越来越依赖于信息化的管理。所以系统开发将围绕牙科门诊工作的实际情况,使之能迅速适应各牙科诊所的需要。
牙科诊所管理系统的实现的现实意义:减少管理诊所的工作人员;管理人员可以随时浏览查看,而且更加直观;改变了以前工资手工记录的方式,电脑录入更加快捷方便;实现了门诊管理系统的计算机化。
随着私人牙科诊所病例数字化建设的蓬勃发展,数字化私人牙科诊所病例的理念已经被广大私人牙科诊所病例所接受,目前面临的主要问题是如何去建设数字化私人牙科诊所病例。
因此,目前我国数字化私人牙科诊所病例的建设重点必须以医疗数字化为主,即着重发展私人牙科诊所病例内与医疗活动相关的各类信息的数字化管理和综合利用,实现诊疗工作的数字化以及医疗流程的自动化,并保证系统的开放性,为将来扩展到区域医疗打下基础。相应地,医疗信息系统作为数字化私人牙科诊所病例建设的系统基础,它的研究重点也将转为面向纯粹医疗活动的各类医疗信息系统及其集成研究。以医疗数字化为建设重点的数字化私人牙科诊所病例的总体规划,它通过各类医疗信息系统的有机集成而实现。可以说,新一代医疗信息系统将在“数字化私人牙科诊所病例”的建设中发挥举足轻重的作用。
## 1.3 结构概述和技术介绍
### 1.3.1 JSP概述
JSP是服务器端脚本环境可以用来创建交互式Web应用程序。当服务器收到对JSP文件的请求时它处理包含在用于构建发送给浏览器的Web页文件中的服务器端脚本。除服务器端脚本外JSP文件也可以包含HTML包括相关的客户端脚本和COM组件调用这些组件可执行不同任务如连接到数据库或处理商业逻辑。
- **对于HTML创作者**HTML创作者将会发现用JSP编写服务器端脚本可使创建更为复杂、使用的Web应用程序变得十分简单。JSP对于将HTML表单信息存储在数据库中、根据访问者的自选项自定义Web站点或对不同的浏览器使用不同的HTML功能提供了优异的解决方案。例如从前要在Web服务器上处理用户输入必须首先用Perl或C等语言建立传统的公共网关接口CGI应用程序。而使用JSP后仅通过在HTML文档中直接嵌入的简单服务器端脚本便可以收集HTML表单信息并传递到数据库。如果已熟悉Microsoft JSPScript或MicrosoftrJscript那么学习JSP将不会感觉到困难
- **对于高级Web脚本语言编写者**由于JSP使用了中性语言因此只要熟悉JSPScript、Jscript或PERL等脚本语言就了解了JSP的使用方法。在JSP页中可以使用已经装有COM脚本兼容编辑引擎的任何脚本编辑语言。JSP使用java和Jscript脚本引擎但仍可安装用于PERL、REXX和Python的脚本引擎他们可从第三方供应商处获得
- **对于Web开发和编程人员**如果使用Visual Basic、C++或Java等编程语言开发过后端Web应用程序将会发现JSP是创建Web应用程序灵活而快速的方法。除了添加脚本为应用程序创建HTML界面之外还可以建立自己的COM组件。可以将应用程序的商业逻辑封装在可重复使用的模块中以便在脚本、其他组件或其他程序中调用
- **Active Server Pages模型**当浏览器向Web服务器请求.JSP文件时服务器断脚本便开始运行。于是Web服务器调用JSP用它从头至尾处理所请求的文件、执行脚本命令并将Web页发送到浏览器。因为脚本运行于服务器而不是客户端所以Web服务器负责生成发送到浏览器的HTML页等工作。服务器端脚本无法被预先复制因为返回到浏览器的只是脚本的运行结果用户无法得知当前页面的脚本命令
### 1.3.2 JSP的新特性
JSP新增了许多特性有助于轻松编写脚本和开发Web应用程序。
- **新的流控制能力**JSP的Server对象具有两种可用来控制程序流的新方法Server .Transfer 和Server .Execute。与重定向请求需要往返于客户端不同使用这些方法可将请求直接传送到.JSP文件而不需要离开服务器
- **错误处理**JSP具有新的错误处理能力可以使用自定义的错误信息.JSP文件来捕捉错误也可以使用新的Server.GetlastError方法来显示有用信息如错误描述或发生错误的行号
- **无脚本**通常JSP静态内容的处理速度快于服务器端内容的处理速度因此以前只将.JSP文件扩展名指派给包含JSP功能性的文件。无论何时如果需要在静态.html文件中添加JSP只能手工添加.JSP文件扩展名并修正相关超级链接。不过在JSP的最新版本中不包含服务器端功能性的.JSP文件的处理速度比以前快了许多。因此如果正在创建展开的Web应用程序并且其中的文件最终可能需要JSP功能性现在就可以很方便地为这些文件指派.JSP文件扩展名而不必考虑他们是否包含静态或服务器端内容
- **性能增强的对象**JSP提供流行的可安装组件的性能怎增强版本。这些对象能够可靠的使用与各种Web发布环境
- **XML集成**XML(扩展表及语言)允许描述复杂的数据结构或文档可以在各种应用程序、客户端和服务器之间共享此信息。使用Microsoft Internet Explorer 4.0或根高版本附带的Microsoft XML Parser可以创建服务器端应用程序该应用程序允许Web服务器与Internet Explorer4.0(或更高版本)或任何包含XML结息能力的服务器交换XML格式的数据
- **Windows脚本组件**JSP支持Microsoft强大的脚本新技术——Windows脚本组件。现在可以将商业逻辑脚本过程转换为可以重复使用的COM组件该组件可用于Web应用程序和其他组件对象模型COM适用的程序
- **确定浏览器能力的新方法**JSP具有可确定浏览器准确能力的新特性。当浏览器发送能描述其能力的Cookie可通过使用简单的客户端脚本来安装这样的Cookie可以创建一个“浏览器能力组件”实例以便检索随Cookie返回的浏览器属性。可以使用此特性来确定浏览器能力并对应用程序做相应调整
- **JSP自动调整**JSP现在可以检测执行请求何时被外外部资源阻断并自动提供更多县城以便同时执行附加请求和继续正常处理。如果CPU负担过重JSP将减少线程数量以便减少因太多费阻断请求同时执行而产生的持续不断的交换
- **服务器端包含使用SRC属性**现在可以使用HTMLSCRIPT/SCRIPT标签的SRC属性来完成服务器端包含。当使用SRC属性制定虚拟或相对路径并使用RUNAT=SERVER属性表示服务器端执行时可以完成与“#Include”命令一样的功能
- **编码的JSP脚本**以前Web开发人员禁止他人查看隐藏在脚本后面的逻辑。JSP现在支持Microsoft Visual Basic Scripting EditionJSPScript和Microsoft Jscript5.0 附带的新的脚本编码实用程序。Web开发人员可以对客户端和服务器端脚本应用编码方案以便使程序逻辑使用非标准ASCCII字符不可读。已编码的脚本在运行时由脚本引擎解码因此不需要单独的实用程序。虽然此特性不是专门的安全加密解决方案但可防止大多数用户无意中查看或复制脚本
### 1.3.3 JSP的基本概念
- **URL**URLUniform Resource Location统一资源定位器有协议名、web服务器地址、路径名和文件名四部分组成它只是了文件在Internet中的位置
- **HTML**HTMLHypertext Markup Language超文本标记语言是一种用于编写超文本文档的标记语言它不是一种程序设计语言而是一种结构语言。它具有凭他无关性无论是何种操作系统只要有相应的浏览器程序就可以运行HTML文档
- **Web站点**Web站点是计算机网络上的一个位置它以网页或文档形式提供信息访问者只需通过Web浏览器链接到站点
- **主页**主页是Web站点上一组网页或其他文件的起始页。它是HTML格式的文档可用来说明站点内容、作者所在公司或部门的新闻、指向其他相关文档的链接或站点作者的个人信息等
# 2.系统分析
## 2.1 需求分析
根据调研情况进行分析,认识到完整的管理系统非常复杂 其功能随医院病例规模等条件的变化而不同。目前各种医院病例管理系统的不断涌现但是大多都是针对大型医院来设计的而很少考虑到众多私人牙科诊所病例的实际情况其功能在私人牙科诊所病例并不适用从而增加了院方不必要的投资。此外系统一般也不支持远程访问信息的共享性差。为适应医疗信息管理发展的需要开发基于B/S结构的私人牙科诊所病例管理系统。该系统应具有以下功能
- **登陆模块**,可分为管理员登陆和普通用户医生登录三个模块
- **用户注册模块**,对用户注册的用户名的要求,不同的用户要求要有不同的用户名
- **系统管理模块**,包括添加管理员,管理员密码的修改
- **挂号管理模块**,包括患者的名字、性别、年龄、现住地址和患者简介
- **患者管理模块**,对患者进行增加、患者删除、患者信息的修改
- **开药管理模块**,对药品的增加、删除、修改、查询,患者病历查
- **科室管理模块**,管理员可以新建,修改,删除,科室信息
- **留言管理**,管理员可以新建,修改,删除留言信息
- **预约挂号模块**,用户可以在线进行预约挂号,用户可以选择普通号和专家号
## 2.2 系统设计原则
### 2.1.1 技术可行性
本系统是采用基于Web的程序设计思想进行编制的利用JSP语句结合Microsoft SQL Server 2000后台数据库开发“私人牙科诊所病例信息管理系统”可应用于各大中小型私人牙科诊所病例。整个系统由若干个表、窗口、菜单构成的。用户可通过菜单来调用系统的各项功能。
基于Web的程序设计语言JSP之所以成为功能强大的服务器端程序是因为它为Web编程人员提供了一组功能强大的内置对象通过这些内置对象编程人员可以控制Web页面的各个方面。
### 2.1.2 经济可行性
鉴于次系统是毕业设计,所以本系统不需要多余的格外开发成本,硬件配置和软件配置环境家用机可完全胜任,所以在经济上是可行的。
### 2.1.3 操作可行性
本设计力求界面简单明了,操作简单,便于上手,使用户可以在最短的时间内熟练掌握各功能。所以在操作上是可行的。
### 2.1.4 时间可行性
从时间上看,在两个月的时间里学习相关知识,并开发网站,时间上是有点紧,但是不是不可能实现,通过两个多月的努力功能基本实现。
# 3.概要设计
功能模块的设计是整个系统设计的重要部分,它决定怎么实现系统的功能,不仅要求功能完善,而且还要界面友好,因此,对于一个成功的系统设计,功能模块的设计是关键。
![](http://www.write-bug.com/myres/static/uploads/2021/10/19/a558bafdc615f81798038f2c87f58cb6.writebug)
## 3.1 数据库设计
目前流行的数据库管理系统有Oracle、Mysql DB2、Sybase、MS Access和Microsoft SQL Server等。Oracle和Mysql是性能卓越、稳定可靠的大型数据库管理系统目前拥有较多的用户。 MS Access 是一种性能可靠、使用方便的小型数据库系统。一般而言,数据库是由特定的操作系统环境上的一个或者一组文件组成的,而数据库管理系统一般是由运行于用户计算机或网络上的远程计算机上面的一整套程序组成的。
根据对数据组织方式的不同,数据库系统分成关系数据库、层次数据库和网状数据库。目前常见的数据库系统上基本上都是关系型数据库系统。在关系型数据库系统中,数据被组织成为二维表格形式,表格中的每个数据行称为一条记录或直接称为行,每一个列有时被称为字段或直接称为列,通过指定行和列定位一个指定的数据项。
一个优秀的数据库系统应具备如下特征:
- 最大限度的减少数据的重复存储(称为“冗余”),以减少存储空间的占用
- 尽可能地提高数据的查询(搜索)速度
- 提供灵活的数据组织和统计手段
- 保章数据的安全
本系统采用的数据库是MySQL是一个关系型数据库管理系统 瑞典MySQL AB公司开发目前属于Oracle公司。MySQL是一种关联数据库管理系统关联数据库将数据保存在不同的表中而不是将所有数据放在一个大仓库内这样就增加了速度并提高了灵活性。MySQL的SQL语言是用于访问数据库的最常用标准化语言。由于其体积小、速度快、总体拥有成本低尤其是开放源码这一特点一般中小型网站的开发都选择MySQL作为网站数据库。所有对数据库访问操作的管理信息系统都是根据用户的需求设计的如果对数据库概念理解不深那么设计出的数据库不但访问速度慢让用户不满意而且还存在很多的重复数据大量的浪费计算机资源。所以如何符合逻辑的有组织的设计好数据库使数据库不仅容易维护而且还让用户方便快捷的访问操作这将是一个重点。因此要设计好数据库先了解一下关于数据库的基本概念是必要的。
## 3.2 建立数据库
现在管理数据库的工具是越来越多了 有了他们我们可是很方便的创建数据库删除数据库 还可以通过工具查看数据库的表的结构表中的字段数据进行数据库以及表的设计 极大地方便了我们 。不用再为创建数据库只有使用sql语句提供了方便.。
## 3.3 建立数据库的任务
数据库设计实际上主要是所要处理的数据的表示方法和存储结构的设计。在采用数据库技术之前,这些工作分散在应用程序中进行;在采用数据库技术之后,这些工作可以通过数据库设计集中起来系统地进行。
上图可以看出,进行数据库设计的首要任务是考虑信息需求,也就是数据库要存入什么样的数据。创建数据库并不是仅仅为了存储数据,更主要的目的是从中提取有用的信息。除了考虑数据存储什么数据外,还应考虑存取方式,也就是处理需求。即要根据用户提出的存取要求来设计数据模式和应用程序。
## 3.4 建立数据库的方法
数据库设计方案应该是将用户需求充分融入其中的,所以同用户进行充分的接触和交流是比不可少的。就设计方法来说,应遵循以下几个步骤:
- 确定该数据库中需要的表
- 确定表中需要的字段
- 明确有唯一值的字段
- 确定表之间的关系
- 优化设计
- 输入数据并新建其他数据库对象
建立私人牙科诊所病例信息管理系统的数据库的操作步骤:
- 打开企业管理器在“数据库”上单击鼠标左键之后在弹出的快捷菜单中选择“新建数据库”命令。保存并命名为“demo”
- 在企业管理器,选择“安全性”的“登录”选项单击右键选择“新建登录”创建用户
- 选择“demo”中的“表”单击右键弹出快捷菜单选择“新建表”命令在显示的窗口中设置表中各个字段的名称、数据类型、长度和允许空等信息并保存
- 选择用户信息表,单击鼠标右键。在弹出的快捷菜单中选择“打开表”然后选择“返回所有行”命令,在显示的窗口中输入表的信息,然后关闭窗口,完成在表中输入信息的工作
这样名为demo的数据库就建成了系统建立的数据库文件扩展名为.sql,文件主名是在database name编辑框中键入的数据库名称。
## 3.5 数据项和数据结构
用户身份包括的数据项用户身份ID号、用户身份名称其E-R图如图3-1所示
![](http://www.write-bug.com/myres/static/uploads/2021/10/19/13ab05f45a70586323c5226f5d45bc0b.writebug)
用户登录信息包括的数据项有用户名称、用户密码、用户身份、用户登录次数其E-R图如图3-2所示
![](http://www.write-bug.com/myres/static/uploads/2021/10/19/311e50cfa2f37abf26b4923999808698.writebug)
用户登录日志信息包括的数据项有日志记录编号、用户编号、登录时间、离开时间其E-R图如图3-3所示
![](http://www.write-bug.com/myres/static/uploads/2021/10/19/d0b0ec57f82f227b3b3600d6ef19c847.writebug)
## 3.6 建立数据表
在系统数据库设计中,数据表的设计是关键,如何根据系统要实现的功能合理地设计数据表,将关系到整个系统数据表的运行效率甚至整个系统的成败,在表设计中要注意遵循数据库计数的原则。
规范化逻辑数据库设计包括使用正规的方法来讲数据分为多个相关的表。拥有大量窄表列较少的表是规范化数据库的特征。而拥有少量宽表列较多的表是非规范化的特征。数据库表设计理论的基本原理是每个表都应有一个惟一的行标识符可以使用列或列集将任何单个记录同表中的所有其他记录去区别开来。每个表都应有一个ID列任何两个记录都不可以共享同一ID值。作为表的唯一行标识符的一列或多列是表的主键。同是表应只能存储单一类型实体的数据并且应避免可为空的列更重要的是表不应有重复的值或列。
因为私人牙科诊所病例信息管理系统包括挂号信息管理、药品管理等模块,还有其他子模块构成,包括的数据比较多,每一个表都要确定主关键字。这样本系统所有的表结构都建成了。
**sysuser表**
| 字段 | 字段名 | 数据类型 | 长度 | 说明 |
| ---- | -------- | ------- | ---- | ---- |
| 1 | id | Int | 4 | 编号 |
| 2 | uname | varchar | 50 | |
| 3 | upass | varchar | 50 | |
| 4 | tname | varchar | 50 | |
| 5 | sex | varchar | 50 | |
| 6 | birth | varchar | 50 | |
| 7 | tel | varchar | 50 | |
| 8 | ismarage | varchar | 50 | |
| 9 | addr | varchar | 50 | |
| 10 | email | varchar | 50 | |
| 11 | idcard | varchar | 50 | |
| 12 | byschool | varchar | 50 | |
| 13 | utype | varchar | 50 | |
| 14 | dept | varchar | 50 | |
**notice信息表**
| 字段 | 字段名 | 数据类型 | 长度 | 说明 |
| ---- | -------- | ------- | ---- | ---- |
| 1 | id | Int | 4 | 编号 |
| 2 | title | varchar | 50 | |
| 3 | note | varchar | 50 | |
| 4 | savetime | varchar | 50 | |
**zd信息表**
| 字段 | 字段名 | 数据类型 | 长度 | 说明 |
| ---- | ---------- | ------- | ---- | ---- |
| 1 | ghno | Int | 4 | 编号 |
| 2 | bg | varchar | 50 | |
| 3 | zd | varchar | 50 | |
| 4 | info | varchar | 50 | |
| 5 | numinfo | varchar | 50 | |
| 6 | oper | varchar | 50 | |
| 7 | savetime | varchar | 50 | |
| 8 | qystatus | varchar | 50 | |
| 9 | fkstatus | varchar | 50 | |
| 10 | totalprice | varchar | 50 | |
| 11 | sfoper | varchar | 50 | |
| 12 | sfsavetime | varchar | 50 | |
| 13 | fyoper | varchar | 50 | |
| 14 | fysavetime | varchar | 50 | |
# 4.详细设计
## 4.1 模块的设计
### 4.1.1 登录模块
**管理员登录**:包括用户名、密码 ,注册用户 界面图如图4-1所示
![](http://www.write-bug.com/myres/static/uploads/2021/10/19/b87a2e85e1af0fbd98a2eed550274659.writebug)
**实现管理员登陆界面的部分代码如下**
```html
<title>私人牙科诊所病例管理系统 </title>
<meta http-equiv="pragma" content="no-cache">
<meta http-equiv="cache-control" content="no-cache">
<meta http-equiv="expires" content="0">
<meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
<meta http-equiv="description" content="This is my page">
<!--
<link rel="stylesheet" type="text/css" href="styles.css">
-->
<LINK href="admin/css/admin.css" type="text/css" rel="stylesheet">
</head>
<%
String message = (String)request.getAttribute("message");
if(message == null){
message = "";
}
if (!message.trim().equals("")){
out.println("<script language='javascript'>");
out.println("alert('"+message+"');");
out.println("</script>");
}
request.removeAttribute("message");
String code=yzm.getCheckCode();
%>
<body onload=document.f1.uname.focus();>
<form action="/srykzsblmis/studysite?ac=login" method="post" name="f1" onsubmit="return ck()">
<TABLE height="100%" cellSpacing=0 cellPadding=0 width="100%" bgColor=#002779
border=0>
<TR>
<TD align=middle>
<TABLE cellSpacing=0 cellPadding=0 width=468 border=0>
<TR>
<TD align="center"><font size="4" color="white"><b>私人牙科诊所病例管理系统 </b></font></TR>
<TR>
<TD><IMG height=147 src="admin/images/login_2.jpg"
width=468></TD></TR></TABLE>
<TABLE cellSpacing=0 cellPadding=0 width=468 bgColor=#ffffff border=0>
<TR>
<TD width=16><IMG height=122 src="admin/images/login_3.jpg"
width=16></TD>
<TD align=middle>
<TABLE cellSpacing=0 cellPadding=0 width=230 border=0>
<TR height=5>
<TD width=5></TD>
<TD width=56></TD>
<TD></TD></TR>
<TR height=36>
<TD></TD>
<TD>用户名</TD>
<TD><INPUT
style="BORDER-RIGHT: #000000 1px solid; BORDER-TOP: #000000 1px solid; BORDER-LEFT: #000000 1px solid; BORDER-BOTTOM: #000000 1px solid"
maxLength=30 size=24 name=uname></TD></TR>
<TR height=36>
<TD>&nbsp; </TD>
<TD>口 令</TD>
<TD><INPUT
style="BORDER-RIGHT: #000000 1px solid; BORDER-TOP: #000000 1px solid; BORDER-LEFT: #000000 1px solid; BORDER-BOTTOM: #000000 1px solid"
type=password maxLength=30 size=24 name=upass></TD></TR>
<TR >
<TD>&nbsp; </TD>
<TD>验证码</TD>
<TD><input type="text" style="BORDER-RIGHT: #000000 1px solid; BORDER-TOP: #000000 1px solid; BORDER-LEFT: #000000 1px solid; BORDER-BOTTOM: #000000 1px solid"
size="5" id="yzm" name="yzm" class=input onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^\d]/g,''))"
onkeyup="value=value.replace(/[\W]/g,'')"><%=code %></TD></TR>
<TR height=5>
<TD colSpan=3></TD></TR>
<TR>
<TD>&nbsp;</TD>
<TD>&nbsp;</TD>
<TD><INPUT type=image height=18 width=70
src="admin/images/bt_login.gif"></TD></TR></TABLE></TD>
```
**普通用户登录**只有合法的用户在输入正确的密码后方可进入系统否则将提示密码或用户名输入错误并询问用户是否重新输入界面图如图4-2所示
![](http://www.write-bug.com/myres/static/uploads/2021/10/19/d5e4525fd4625b7ff32085f4bb98a0d8.writebug)
**实现普通用户登录的部分代码如下**
```html
<jsp:include page="top.jsp"></jsp:include>
<%HashMap user = (HashMap)session.getAttribute("user");
CommDAO dao = new CommDAO();
HashMap map = dao.select("select * from patient where id='"+user.get("id")+"' ").get(0);%>
<div style="margin-top:10px;text-align:center;">
<table width=800 border="0" cellpadding="0" cellspacing="0">
<tr height=320 bgcolor="#1FA9FE" style="color:white;font-weight:bold;">
<td align="center" width=110 bgcolor="#ECECED" valign="top" style="">
<jsp:include page="menu.jsp"></jsp:include>
</td>
<td align="center" bgcolor="white" style="padding-left:20px;padding-top:15px;color:Black;font-weight:normal;" valign="top">
<form action="/srykzsblmis/studysite?ac=userinfo&id=<%=map.get("id") %>" name="f1" method="post" onsubmit="return ck()">
<table border=0 style="font-size:12px">
<tr bgcolor="#ffffff">
<td width=130 >
登录名称:
</td>
<td width=570 align="left">
<input name="uname" type="text" id="uname" style="width:150px;" />&nbsp;
</td>
</tr>
<tr bgcolor="#ffffff">
<td >
登录密码:
</td>
<td align="left">
<input name="upass" type="password" id="upass" style="width:150px;" />&nbsp;
</td>
</tr>
<tr bgcolor="#ffffff">
<td >
重复密码:
</td>
<td align="left">
<input name="upass1" type="password" id="upass1" style="width:150px;" />&nbsp;
</td>
</tr>
<tr bgcolor="#ffffff">
<td>病人姓名</td>
<td><input type="text" id="tname" name="tname" size="5"/>*</td>
</tr>
<tr bgcolor="#ffffff">
<td>性别</td>
<td>
<select id="sex" name="sex">
<option value="男"></option>
<option value="女"></option>
</select>
</td>
</tr>
<tr bgcolor="#ffffff">
<td>年龄</td>
<td><input type="text" id="age" name="age" size="2"/>*</td>
</tr>
<tr bgcolor="#ffffff">
<td>身份证</td>
<td><input type="text" id="idcard" name="idcard" />*</td>
</tr>
<tr bgcolor="#ffffff">
<td>电话</td>
<td><input type="text" id="tel" name="tel" />*</td>
</tr>
<tr bgcolor="#ffffff">
<td>住址</td>
<td><input type="text" id="addr" name="addr" />*</td>
</tr>
<tr height=60>
<td align="center" colspan="2">
<input type="submit" value="提交">
</td>
</tr>
</table>
</form>
</td>
</tr>
</table>
<div style="margin-top:10px;height:1px;background-color:#1FA9FE;text-align:center;width:800px;">
</div>
</div>
<jsp:include page="foot.jsp"></jsp:include>
</center>
<script type="text/javascript">
function ck(){
if(f1.upass.value==""){
alert("密码不能为空");
return false;
}if(f1.upass1.value==""){
alert("再次输入密码");
return false;
}if(f1.upass1.value!=f1.upass.value){
alert("两次密码不一致");
return false;
}if(f1.tname.value==""){
alert("姓名不能为空");
return false;
}if(f1.sex.value==""){
alert("性别不能为空");
return false;
}if(f1.idcard.value==""){
alert("身份证不能为空");
return false;
}
}
<%
String suc = (String)request.getAttribute("suc");
String no = (String)request.getAttribute("no");
if(no!=null)
{
%>
alert("已存在的用户名");
<%}
if(suc!=null)
{
%>
alert("修改成功");
location.replace("/srykzsblmis/userinfo.jsp");
<%}%>
</script>
</body>
</html>
<%=Info.tform(map)%>
```
### 4.1.2 用户注册模块
用户注册包括用户名、登录密码、密码确认界面图如4-3图所示
![](http://www.write-bug.com/myres/static/uploads/2021/10/19/666a69826b11cdb44bdbd0ebaf90d8e7.writebug)
**实现用户注册的部分代码如下**
```html
<title>私人牙科诊所病例管理系统</title>
<meta http-equiv="pragma" content="no-cache">
<meta http-equiv="cache-control" content="no-cache">
<meta http-equiv="expires" content="0">
<meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
<meta http-equiv="description" content="This is my page">
<!--
<link rel="stylesheet" type="text/css" href="styles.css">
-->
<STYLE type=text/css>
BODY
{
padding-right: 0px;
padding-left: 0px;
padding-bottom: 0px;
margin: 0px;
padding-top: 0px;
font-size: 12px;
}
.STYLE2 {
FONT-SIZE: 12px
}
.STYLE3 {
FONT-WEIGHT: bold
}
.style7 {
FONT-FAMILY: "黑体", "方正美黑简体", "华文细黑"; COLOR: #646464; FONT-SIZE: 18px
}
BODY {
BACKGROUND-IMAGE: url(img/lbg.gif); PADDING-BOTTOM: 0px; MARGIN: 0px; PADDING-LEFT: 0px; PADDING-RIGHT: 0px; FONT-SIZE: 12px; PADDING-TOP: 0px
}
.tb {
WIDTH: 926px
}
.td2 {
TEXT-ALIGN: left; PADDING-LEFT: 80px; BACKGROUND-REPEAT: no-repeat; HEIGHT: 100%
}
.txtBox {
BORDER-BOTTOM: #e7ad01 1px solid; BORDER-LEFT: #e7ad01 1px solid; WIDTH: 130px; HEIGHT: 20px; COLOR: #000000; FONT-SIZE: 13px; BORDER-TOP: #e7ad01 1px solid; BORDER-RIGHT: #e7ad01 1px solid
}
# div1 {
}
# diqu {
TEXT-ALIGN: center; WIDTH: 588px; BACKGROUND: url(images/2009_index_04.gif) no-repeat; COLOR: #2e466f
}
# diqu A {
COLOR: #2e466f
}
.pageWidth {
TEXT-ALIGN: left; MARGIN: 0px auto; WIDTH: 850px; BACKGROUND: #ffffff
}
# nav {
PADDING-BOTTOM: 0px; LIST-STYLE-TYPE: none; MARGIN: 1em 0px 0px; PADDING-LEFT: 0px; PADDING-RIGHT: 0px; FONT-SIZE: 16px; FONT-WEIGHT: 200; LIST-STYLE-IMAGE: none; PADDING-TOP: 0px
}
# nav LI {
FONT-FAMILY: "宋体"; FLOAT: left; FONT-SIZE: 14px; MARGIN-RIGHT: 1px
}
# nav LI A {
TEXT-ALIGN: center; LINE-HEIGHT: 35px; MARGIN: 0em 0px 0px; WIDTH: 120.5px; DISPLAY: block; BACKGROUND: #f6ad79; COLOR: #000000; FONT-SIZE: 14px; TEXT-DECORATION: none; PADDING-TOP: 5px
}
.bi:hover SPAN {
TEXT-ALIGN: center; LINE-HEIGHT: 35px; MARGIN: 0em 0px 0px; WIDTH: 120.5px; DISPLAY: block; BACKGROUND: #f6ad79; COLOR: #000000; FONT-SIZE: 14px; TEXT-DECORATION: none; PADDING-TOP: 5px
}
# nav LI A:hover {
BACKGROUND: #dc3e0b; COLOR: #ffffff; FONT-SIZE: 14px; CURSOR: hand; PADDING-TOP: 0px
}
.bi:hover SPAN {
BACKGROUND: #dc3e0b; COLOR: #ffffff; FONT-SIZE: 14px; CURSOR: hand; PADDING-TOP: 0px
}
.bi:hover SPAN {
PADDING-TOP: 5px
}
.la {
COLOR: #044a8e; TEXT-DECORATION: none
}
.la:hover {
TEXT-DECORATION: underline
}
</STYLE>
<LINK rel=stylesheet type=text/css href="/frontfile/css.css">
</head>
<body>
<jsp:include page="top.jsp"></jsp:include>
<div style="margin-top:10px;text-align:center;">
<table width=800 border="0" cellpadding="0" cellspacing="0">
<tr height=320 bgcolor="#1FA9FE" style="color:white;font-weight:bold;">
<td align="center" width=800 bgcolor="#ECECED" valign="top" style="">
<div style="margin-left:20px;font-size:16px;font-weight:bold;color:#044A8E;margin-top:20px;text-align:center;">
用户注册
</div>
<hr>
<div style="font-size:12px;color:#044A8E;margin-top:20px;text-align:center;font-weight:normal;">
<form action="/srykzsblmis/studysite?ac=regedit" name="f1" method="post">
<table border=0 width=700 style="font-size:12px">
<tr bgcolor="#ffffff">
<td width=130 >
登录名称:
</td>
<td width=570 align="left">
<input name="uname" type="text" id="uname" style="width:150px;" />&nbsp;
</td>
</tr>
<tr bgcolor="#ffffff">
<td >
登录密码:
</td>
<td align="left">
<input name="upass" type="password" id="upass" style="width:150px;" />&nbsp;
</td>
</tr>
<tr bgcolor="#ffffff">
<td >
重复密码:
</td>
<td align="left">
<input name="upass1" type="password" id="upass1" style="width:150px;" />&nbsp;
</td>
</tr>
<tr bgcolor="#ffffff">
<td>病人姓名</td>
<td><input type="text" id="tname" name="tname" size="5"/>*</td>
</tr>
<tr bgcolor="#ffffff">
<td>性别</td>
<td>
<select id="sex" name="sex">
<option value="男"></option>
<option value="女"></option>
</select>
</td>
</tr>
<tr bgcolor="#ffffff">
<td>年龄</td>
<td><input type="text" id="age" name="age" size="2"/>*</td>
</tr>
<tr bgcolor="#ffffff">
<td>身份证</td>
<td><input type="text" id="idcard" name="idcard" />*</td>
</tr>
<tr bgcolor="#ffffff">
<td>电话</td>
<td><input type="text" id="tel" name="tel" />*</td>
</tr>
<tr bgcolor="#ffffff">
<td>住址</td>
<td><input type="text" id="addr" name="addr" />*</td>
</tr>
<tr height=60>
<td align="center" colspan="2">
<img src="images/reg.png" border="0" onclick="ck()"/>
</td>
</tr>
</table>
</form>
</div>
</td>
</tr>
</table>
<div style="margin-top:10px;height:1px;background-color:#1FA9FE;text-align:center;width:800px;">
</div>
</div>
<jsp:include page="foot.jsp"></jsp:include>
<script type="text/javascript">
function ck(){
if(f1.uname.value==""){
alert("用户名不能为空");
return false;
}if(f1.upass.value==""){
alert("密码不能为空");
return false;
}if(f1.upass1.value==""){
alert("再次输入密码");
return false;
}if(f1.upass1.value!=f1.upass.value){
alert("两次密码不一致");
return false;
}if(f1.tname.value==""){
alert("姓名不能为空");
return false;
}if(f1.sex.value==""){
alert("性别不能为空");
return false;
}if(f1.idcard.value==""){
alert("身份证不能为空");
return false;
}else{
f1.submit();
}
```
### 4.1.3 系统管理模块
系统管理模块是私人牙科诊所病例信息管理系统中一个基础的部分在本模块中包括管理员对自身密码的重新设置可以定时更换密码确保资料的安全同时还有登陆日志模块记录每一次登陆信息如果出现特殊情况可以查询登陆日志查询增加了系统的安全性和保密性便于控制和管理界面图如图4-4所示
![](http://www.write-bug.com/myres/static/uploads/2021/10/19/463671bac1538c1f6d28f41bb11c2b5c.writebug)
**实现系统界面的部分代码如下**
```java
//添加科室
if(ac.equals("deptadd")){
String deptname = request.getParameter("deptname");
String tel = request.getParameter("tel");
String addr = request.getParameter("addr");
String delstatus = "0";
String sql = "insert into dept (deptname,tel,addr,delstatus) values('"+deptname+"','"+tel+"','"+addr+"','"+delstatus+"')";
dao.commOper(sql);
request.setAttribute("suc", "");
go("/admin/deptadd.jsp", request, response);
}
//修改科室
if(ac.equals("deptedit")){
String id = request.getParameter("id");
String tel = request.getParameter("tel");
String addr = request.getParameter("addr");
String deptname = request.getParameter("deptname");
String sql = "update dept set deptname='"+deptname+"',tel='"+tel+"',addr='"+addr+"' where id= "+id;
dao.commOper(sql);
request.setAttribute("suc", "");
go("/admin/deptadd.jsp", request, response);
}
//添加药品、处置
if(ac.equals("ypcfadd")){
String yno = request.getParameter("yno");
String cksql = "select * from ypcf where yno='"+yno+"'";
ArrayList cklist = (ArrayList)dao.select(cksql);
if(cklist.size()!=0){
request.getParameter("no");
go("/admin/ypcfadd.jsp", request, response);
}else{
String yname = request.getParameter("yname");
String price = request.getParameter("price");
String type = request.getParameter("type");
String gg = request.getParameter("gg");
String company = request.getParameter("company");
if(!type.equals("药品")){
gg = "";
company = "";
}
String delstatus = "0";
String sql = "insert into ypcf (yno,yname,gg,price,company,delstatus,type)values('"+yno+"','"+yname+"','"+gg+"','"+price+"','"+company+"','"+delstatus+"','"+type+"')";
dao.commOper(sql);
request.setAttribute("suc", "");
go("/admin/ypcfadd.jsp", request, response);
```
### 4.1.4 挂号管理模块
挂号管理模块是私人牙科诊所病例信息管理系统中一个部分本模块主要实现后台管理包括添加、删除、修改患者挂号添加功能如图4-5所示
![](http://www.write-bug.com/myres/static/uploads/2021/10/19/a2093b737ebdd7e3f9f8a351dce3bd39.writebug)
### 4.1.5病例管理模块
医生可以对病人病例信息进行管理在本模块中包括所有患者的信息的添加、删除、修改增加患者图如图4-6所示
![](http://www.write-bug.com/myres/static/uploads/2021/10/19/af7d8817606e763d23f1e7bc8318b2dc.writebug)
### 4.1.6 用户模块
用户可以预约就诊可以对个人信息进行管理可以查询病例信息同时可以与医生进行在线交流留言在本模块中包括所有添加、删除、修改、查询如图4-7所示
![](http://www.write-bug.com/myres/static/uploads/2021/10/19/83a3db1b29a4cda857830eec0cbce363.writebug)
# 5.系统调试与测试
## 5.1 程序调试
在设计系统的过程中,存在一些错误是必然的。对于语句的语法错误,在程序运行时自动提示,并请求立即纠正,因此,这类错误比较容易发现和纠正。但另一类错误是在程序执行时由于不正确的操作或对某些数据的计算公式的逻辑错误导致的错误结果。这类错误隐蔽性强,有时会出现,有时又不出现,因此,对这一类动态发生的错误的排查是耗时费力的。
## 5.2 软件的测试
### 5.2.1 测试的重要性及目的
#### 测试的重要性
软件的测试在软件生命周期中占据重要的地位,在传统的瀑布模型中,软件测试学仅处于运行维护阶段之前,是软件产品交付用户使用之前保证软件质量的重要手段。近来,软件工程界趋向于一种新的观点,即认为软件生命周期每一阶段中都应包含测试,从而检验本阶段的成果是否接近预期的目标,尽可能早的发现错误并加以修正,如果不在早期阶段进行测试,错误的延时扩散常常会导致最后成品测试的巨大困难。
事实上对于软件来讲不论采用什么技术和什么方法软件中仍然会有错。采用新的语言、先进的开发方式、完善的开发过程可以减少错误的引入但是不可能完全杜绝软件中的错误这些引入的错误需要测试来找出软件中的错误密度也需要测试来进行估计。测试是所有工程学科的基本组成单元是软件开发的重要部分。自有程序设计的那天起测试就一直伴随着。统计表明在典型的软件开发项目中软件测试工作量往往占软件开发总工作量的40以上。而在软件开发的总成本中用在测试上的开销要占30到50。如果把维护阶段也考虑在内讨论整个软件生存期时测试的成本比例也许会有所降低但实际上维护工作相当于二次开发乃至多次开发其中必定还包含有许多测试工作。
在实践中,软件测试的困难常常使人望而却步或敷衍了事,这是由于对测试仍然存在一些不正确的看法和错误的态度,这包括:
- 认为测试工作不如设计和编码那样容易取得进展难以给测试人员某种成就感
- 以发现软件错误为目标的测试是非建设性的,甚至是破坏性的,测试中发现错位是对责任者工作的一种否定
- 测试工作枯燥无味,不能引起人们的兴趣
- 测试工作是艰苦而细致的工作
- 对自己编写的程序盲目自信,在发现错误后,顾虑别人对自己的开发能力的看法
这些观点对软件测试工作是极为不利的,必须澄清认识、端正态度,才可能提高软件产品的质量。
### 测试的目的
如果测试的目的是为了尽可能多地找出错误,那么测试就应该直接针对软件比较复杂的部分或是以前出错比较多的位置。如果测试目的是为了给最终用户提供具有一定可信度的质量评价,那么测试就应该直接针对在实际应用中会经常用到的商业假设。
在谈到软件测试时许多人都引用Grenford J. Myers在《The Art of Software Testing》一书中的观点
- 软件测试是为了

Binary file not shown.

Binary file not shown.

View File

@ -0,0 +1,206 @@
/*
MySQL Data Transfer
Source Host: localhost
Source Database: srykzsblmis_db
Target Host: localhost
Target Database: srykzsblmis_db
Date: 2016/3/23 17:48:55
*/
SET FOREIGN_KEY_CHECKS=0;
-- ----------------------------
-- Table structure for chat
-- ----------------------------
DROP TABLE IF EXISTS `chat`;
CREATE TABLE `chat` (
`id` int(11) NOT NULL auto_increment,
`msg` text,
`hfmsg` text,
`savetime` varchar(255) default NULL,
`uid` varchar(255) default NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
-- ----------------------------
-- Table structure for dept
-- ----------------------------
DROP TABLE IF EXISTS `dept`;
CREATE TABLE `dept` (
`id` int(11) NOT NULL auto_increment,
`deptname` varchar(255) default NULL,
`addr` varchar(255) default NULL,
`delstatus` varchar(255) default NULL,
`tel` varchar(255) default NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
-- ----------------------------
-- Table structure for ghinfo
-- ----------------------------
DROP TABLE IF EXISTS `ghinfo`;
CREATE TABLE `ghinfo` (
`id` int(11) NOT NULL auto_increment,
`ghno` varchar(255) default NULL,
`tname` varchar(255) default NULL,
`sex` varchar(255) default NULL,
`age` varchar(255) default NULL,
`idcard` varchar(255) default NULL,
`tel` varchar(255) default NULL,
`addr` varchar(255) default NULL,
`ghdept` varchar(255) default NULL,
`price` varchar(255) default NULL,
`delstatus` varchar(255) default NULL,
`status` varchar(255) default NULL,
`oper` varchar(255) default NULL,
`savetime` varchar(255) default NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
-- ----------------------------
-- Table structure for kcrecord
-- ----------------------------
DROP TABLE IF EXISTS `kcrecord`;
CREATE TABLE `kcrecord` (
`id` bigint(20) NOT NULL auto_increment,
`yno` varchar(255) default NULL,
`num` varchar(255) default NULL,
`type` varchar(255) default NULL,
`oper` varchar(255) default NULL,
`savetime` varchar(255) default NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
-- ----------------------------
-- Table structure for notice
-- ----------------------------
DROP TABLE IF EXISTS `notice`;
CREATE TABLE `notice` (
`id` int(11) NOT NULL auto_increment,
`title` varchar(255) default NULL,
`note` text,
`savetime` varchar(255) default NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
-- ----------------------------
-- Table structure for patient
-- ----------------------------
DROP TABLE IF EXISTS `patient`;
CREATE TABLE `patient` (
`id` int(11) NOT NULL auto_increment,
`uname` varchar(255) default NULL,
`upass` varchar(255) default NULL,
`tname` varchar(255) default NULL,
`sex` varchar(255) default NULL,
`age` varchar(255) default NULL,
`idcard` varchar(255) default NULL,
`tel` varchar(255) default NULL,
`addr` varchar(255) default NULL,
`delstatus` varchar(255) default NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
-- ----------------------------
-- Table structure for sysuser
-- ----------------------------
DROP TABLE IF EXISTS `sysuser`;
CREATE TABLE `sysuser` (
`id` int(11) NOT NULL auto_increment,
`uname` varchar(255) default NULL,
`upass` varchar(255) default NULL,
`tname` varchar(255) default NULL,
`sex` varchar(255) default NULL,
`birth` varchar(255) default NULL,
`tel` varchar(255) default NULL,
`ismarage` varchar(255) default NULL,
`addr` varchar(255) default NULL,
`email` varchar(255) default NULL,
`idcard` varchar(255) default NULL,
`byschool` varchar(255) default NULL,
`utype` varchar(255) default NULL,
`dept` varchar(255) default NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
-- ----------------------------
-- Table structure for ypcf
-- ----------------------------
DROP TABLE IF EXISTS `ypcf`;
CREATE TABLE `ypcf` (
`id` bigint(20) NOT NULL auto_increment,
`yno` varchar(255) default NULL,
`yname` varchar(255) default NULL,
`gg` varchar(255) default NULL,
`price` varchar(255) default NULL,
`type` varchar(255) default NULL,
`company` varchar(255) default NULL,
`delstatus` varchar(255) default NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
-- ----------------------------
-- Table structure for yy
-- ----------------------------
DROP TABLE IF EXISTS `yy`;
CREATE TABLE `yy` (
`id` int(11) NOT NULL auto_increment,
`uid` varchar(255) default NULL,
`dept` varchar(255) default NULL,
`type` varchar(255) default NULL,
`ghno` varchar(255) default NULL,
`savetime` varchar(255) default NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
-- ----------------------------
-- Table structure for zd
-- ----------------------------
DROP TABLE IF EXISTS `zd`;
CREATE TABLE `zd` (
`ghno` varchar(255) default NULL,
`bq` text,
`zd` text,
`info` text,
`numinfo` text,
`oper` varchar(255) default NULL,
`savetime` varchar(255) default NULL,
`qystatus` varchar(255) default NULL,
`fkstatus` varchar(255) default NULL,
`totalprice` double default NULL,
`sfoper` varchar(255) default NULL,
`sfsavetime` varchar(255) default NULL,
`fyoper` varchar(255) default NULL,
`fysavetime` varchar(255) default NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
-- ----------------------------
-- Records
-- ----------------------------
INSERT INTO `chat` VALUES ('1', '呵了', '好,测试成功', '2016-03-23 17:35:42', '1');
INSERT INTO `chat` VALUES ('2', '我来了', '我知道 ', '2016-03-23 17:40:44', '2');
INSERT INTO `dept` VALUES ('1', '牙科', '一楼', '0', '88888888');
INSERT INTO `ghinfo` VALUES ('1', '20160323044944', '小明', '', '23', '428888197712122222', '13265443456', '湖北武汉光谷1路', '1', '10', '0', '已问诊', '网上预约', '2016-03-23 16:49:44');
INSERT INTO `ghinfo` VALUES ('2', '20160323044950', '小方', '', '18', '427666198510084567', '13222222222', '湖南长沙芙蓉大道88号', '1', '5', '0', '已问诊', 'gh', '2016-03-23 16:50:11');
INSERT INTO `ghinfo` VALUES ('3', '20160323054406', '美美', '', '23', '428888197711110099', '13666666611', '硚口宝丰一路', '1', '10', '0', '已问诊', '网上预约', '2016-03-23 17:44:06');
INSERT INTO `kcrecord` VALUES ('1', 'NO0002', '100', 'in', 'yf', '2016-03-23 17:03:13');
INSERT INTO `kcrecord` VALUES ('2', 'NO0002', '1', 'out', 'yf', '2016-03-23 17:03:17');
INSERT INTO `kcrecord` VALUES ('3', 'NO0002', '3', 'out', 'yf', '2016-03-23 17:46:28');
INSERT INTO `kcrecord` VALUES ('4', 'NO0004', '100', 'in', 'yf', '2016-03-23 17:46:42');
INSERT INTO `notice` VALUES ('2', '测试公告的啦', '呵呵', '2016-03-23 17:15:41');
INSERT INTO `notice` VALUES ('3', '测试的公告', '123123123', '2016-03-23 17:41:17');
INSERT INTO `patient` VALUES ('1', 'xm', '123', '小明', '', '23', '428888197712122222', '13265443456', '湖北武汉光谷1路', '0');
INSERT INTO `patient` VALUES ('2', 'mm', '123', '美美', '', '23', '428888197711110099', '13666666611', '硚口宝丰一路', '0');
INSERT INTO `sysuser` VALUES ('1', 'admin', '123', '老胡', '', null, null, null, null, null, null, null, '管理员', null);
INSERT INTO `sysuser` VALUES ('2', 'gh', '123', '张三', '', '1982-03-23', '13412312312', '已婚', '人民北路10号', 'gh@163.com', '427777198810098765', '武汉医学院', '挂号人员', '');
INSERT INTO `sysuser` VALUES ('3', 'sf', '123', '李四', '', '1992-03-23', '13099987777', '未婚', '南京路9号', 'sf@163.com', '428888197712120099', '上海交大', '收费人员', '');
INSERT INTO `sysuser` VALUES ('4', 'yf', '123', '王五', '', '1984-03-23', '13000000000', '未婚', '解放大道9号', 'yf@163.com', '426345198810108822', '北京大学', '药房人员', '');
INSERT INTO `sysuser` VALUES ('5', 'doctor1', '123', '赵六', '', '1973-03-23', '13412344322', '未婚', '龙王庙1号', 'doctor1@163.com', '427666195110084567', '工程大学', '医生', '1');
INSERT INTO `ypcf` VALUES ('1', 'NO0001', '消毒费', '', '5', '处置', '', '0');
INSERT INTO `ypcf` VALUES ('2', 'NO0002', '阿莫西林胶囊', '', '15.5', '药品', '西安杨森', '0');
INSERT INTO `ypcf` VALUES ('3', 'NO0003', '诊断费', '', '10', '处置', '', '0');
INSERT INTO `ypcf` VALUES ('6', 'NO0004', '红霉素软胶囊', '', '6', '药品', '白云山制药', '0');
INSERT INTO `yy` VALUES ('1', '1', '1', '10', '20160323044944', '2016-03-23 16:45:38');
INSERT INTO `yy` VALUES ('3', '2', '1', '10', '20160323054406', '2016-03-23 17:40:59');
INSERT INTO `zd` VALUES ('20160323044950', '牙齿发炎,红肿', '长智齿', 'NO0001-消毒费-5元$NO0002-阿莫西林胶囊-15.5元$', '1$1$', 'doctor1', '2016-03-23 16:57:32', '已取药', '已付款', '20.5', 'sf', '2016-03-23 17:00:31', 'yf', '2016-03-23 17:03:17');
INSERT INTO `zd` VALUES ('20160323044944', '吃东西总是夹菜', '有蛀牙,消个毒就好', 'NO0001-消毒费-5元$', '1$', 'doctor1', '2016-03-23 16:59:23', '已取药', '已付款', '5', 'sf', '2016-03-23 17:00:20', 'yf', '2016-03-23 17:03:19');
INSERT INTO `zd` VALUES ('20160323054406', '说头很痛', '牙齿发炎导致,消下毒,吃点药', 'NO0002-阿莫西林胶囊-15.5元$NO0001-消毒费-5元$', '3$1$', 'doctor1', '2016-03-23 17:45:25', '已取药', '已付款', '51.5', 'sf', '2016-03-23 17:46:00', 'yf', '2016-03-23 17:46:31');

BIN
源代码/srykzsblmis.zip Normal file

Binary file not shown.