ImageVerifierCode 换一换
格式:DOCX , 页数:18 ,大小:191.50KB ,
资源ID:7567507      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/7567507.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(医院住院部信息管理系统.docx)为本站会员(b****6)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

医院住院部信息管理系统.docx

1、医院住院部信息管理系统医院住院部信息管理系统1绪论医院住院部信息管理系统方便医生和病人搜索相关住院信息,并且实现从住院、治疗到出院的全过程精确管理与监控,大幅度减少住院治疗事故,对于常出现医疗和财务纠纷的细节,可以极大地节约成本,提升医院整体效益,赢得长足发展。医院住院部信息管理系统是现代化医院运营的必要技术支撑和基础设施,实现医院住院部信息管理系统的目的就是为了以更现代化、科学化、规范化的手段来加强医院的管理,提高医院的工作效率,改进医院质量,从而树立现代医院的新形象,这也是未来医院发展的必然方向。2需求分析作为医院住院部这样的的场所,其经济成分比重相对较多,对于患者来说来说主要有住院,缴费

2、等情况。而医院则是针对患者入院后对其进行治疗方面。如何让这么多患者实行分类治疗信息管理正是医院住院部信息系统的目的所在。本系统综合了经济的角度,建立了信息中心,可将来各自患者的信息集中管理,提高医院住院部管理的高效性和有序性,快速反馈了患者信息。从系统开发及实施的可行性和灵活性考虑,本系统的软件开发环境主要选择了当前较为流行的功能强大的 SQL sever 2005 数据库。3总体设计对数据库进行总体分析设计,掌握所要进行设计的数据库的基本框架,并考虑到数据库的安全完整型的设计。3.1 功能图系统的核心是对住院信息的管理。查询功能也是系统的基本功能。为了实现医院住院部信息管理系统,方便用户和管

3、理与需求,将医院住院部信息管理系统分为:医生管理,病人管理,病房管理,系统维护四个功能模块,如下图3-1。图3-13.2安全设计给数据库中表创建不同的视图,保证数据的安全性,使得不想被人知道的部分信息能够较好地隐藏下来。给数据库中表创建自定义约束,比如check约束、主键约束和唯一键约束,以此来保证数据库的完整性。给数据库创建存储过程和触发器,防止工作人员由于误操作而删掉部分重要信息。4概念结构设计在需求分析阶段所得到的用户需求抽象为信息结构即概念结构模型的过程就是概念结构设计。它是整个数据库设计的关键。这个部分的关键是设计,一般根据系统要求,画出能反映本系统每个应用需求的 E-R 图。其中包

4、括五个实体即医生实体、病人实体、病房实体、治疗实体、入住实体,以及一些实体与属性之间的联系。然后对初始的 E-R 图进行优化,消除冗余和可能存在的矛盾。根据需要得到一个基本的E-R图,如下图4-1所示。图4-1 医院住院部信息管理系统整体E-R图5逻辑结构设计逻辑结构的设计的任务就是把概念结构设计阶段设计好的基本E-R模型转换为与选用DBMS产品所支持的数据模型相符合的逻辑结构。5.1关系模型转化医生表(医生编号,姓名,性别,出生日期,职称,科室)病人表(病人编号,姓名,性别,出生日期,缴费情况,缴费金额,病症)病房表(病房号,床位号,床位数)治疗表(医生编号,病人编号,病人情况,医嘱类型,医

5、嘱内容,治疗时间)入住表(病人编号,病房号,床位号,住院时间,出院时间)5.2确定函数依赖、属于第几范式医生表:医生编号姓名,医生编号姓别,医生编号出生日期,医生编号职称,医生编号科室,没有传递依赖,没有部分依赖,则此范式属于第三范式。病人表:病人编号姓名,病人编号姓别,病人编号出生日期,病人编号缴费情况,病人编号缴费金额,病人编号病症,。没有传递依赖,没有部分依赖,则此范式属于第三范式。病房表:(病房号,床位号)床位数,没有传递依赖,没有部分依赖,则此范式属于第三范式。治疗表:(医生编号,病人编号)病人情况,(医生编号,病人编号)医嘱类型,(医生编号,病人编号)遗嘱内容,(医生编号,病人编号

6、)治疗时间,有传递依赖,没有部分依赖,则此范式属于第三范式。入住表:(病人编号,病房号,床位号)住院时间,(病人编号,病房号,床位号)出院时间,有传递依赖,没有部分依赖,则此范式属于第三范式。6物理结构设计设计中所涉及的表有医生信息表doctor,病人信息表patinet,病房信息表sickroom,治疗情况信息表curecondition,入住信息表intake。表6-1 doctor表列名数据类型宽度允许空值说明列名含义DidNchar10否主键、唯一键职工号DnameNchar16是姓名DsexNchar1是男或女性别DbirthDatetime是出生日期TitleNchar10是职称O

7、fficeNchar10是科室表6-2 patinet表列名数据类型宽度允许空值说明列名含义PidNchar10否主键、唯一键病人编号PnameChar16是姓名PsexNchar1是男或女性别PbirthDatetime是出生日期PmonText是缴费情况PmoneyFloat是缴费金额IllnessText是病症 表6-3 sickroom表列名数据类型宽度允许空值说明列名含义SidNchar10否主键病房号SroomidInt否主键、check约束床位号SnumNchar10是 Check约束床位数表6-4 curecondition表列名数据类型宽度允许空值说明列名含义DidNchar

8、10否主键、外键医生编号PidNchar10否主键、外键病人编号PconditionText是病人情况OrdertypeText是医嘱类型McontentText是医嘱内容CuretimeDatetime是治疗时间表6-5 intake表列名数据类型宽度允许空值说明列名含义PidNchar10否主键、外键病人编号SidNchar10否主键、外键病房号SroomidInt否主键、外键病床号intaketimedatetime是入住时间Outtimedatetime是Check约束出院时间7数据库的实施、运行完成物理结构设计之后,就要用DBMS提供的数据定义语言和其他实用程序将数据库逻辑设计和物理

9、设计结果严格描述出来,成为DBMS可以接受的源代码,再经过调试产生目标文件。7.1创建数据库、建立表经过以上结构设计,使用软件sql server 2005,通过sql语句创建数据库以及以上5个表。7.1.1创建数据库yygl创建数据库所用到的sql语句:CREATE DATABASE yygl ON PRIMARY ( NAME = Nyygl, FILENAME = ND:库yygl.mdf , SIZE = 3072KB , MAXSIZE = UNLIMITED, FILEGROWTH = 1024KB ) LOG ON ( NAME = Nyygl_log, FILENAME = N

10、D:库 yygl_log.ldf , SIZE = 1024KB , MAXSIZE = 2048GB , FILEGROWTH = 10%) COLLATE Chinese_PRC_CI_AS7.1.2创建医生表在医生表中“医生编号”列建立主键约束,使每个医生编号只代表一名医生,“医生编号”不能为空值;在“性别”列上创建check约束,使“性别”属性的取值只能是男或女二者中的一个,不允许出现第三个;在“医生编号”列唯一性约束,保证职工号的唯一性。创建医生信息表所用到的sql语句:CREATE TABLE dbo.doctor( did nchar(10) NOT NULL,dname nch

11、ar(16) NULL, dsex nchar(1) NULL,dbirth datetime NULL, title nchar(10) NULL,office nchar(10) NULL, CONSTRAINT PK_doctor PRIMARY KEY CLUSTERED ( did ASC)WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON PRIMARY,CONSTRAINT uq_key

12、UNIQUE NONCLUSTERED ( did ASC)WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON PRIMARY) ON PRIMARYGOALTER TABLE dbo.doctor WITH CHECK ADD CONSTRAINT CK_doctor CHECK (dsex=女 OR dsex=男)GOALTER TABLE dbo.doctor CHECK CONSTRAINT C

13、K_doctor7.1.3创建病人表在病人表中“病人编号”列建立主键约束,是每一个病人编号都代表着一个病人,“病人编号”不能为空值;在“性别”列上创建check约束,使“性别”属性的取值只能是男或女二者中的一个,不允许出现第三个;在“病人编号”列唯一性约束,保证职工号的唯一性。创建病人信息表所用到的sql语句:CREATE TABLE dbo.patinet( pid nchar(10) NOT NULL,pname nchar(10) NULL, psex nchar(1) NULL,pbirth datetime NULL, pmon text NULL,pmoney float NULL

14、, illness text NULL, CONSTRAINT PK_patinet_1 PRIMARY KEY CLUSTERED (pid ASC)WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON PRIMARY,CONSTRAINT un_p UNIQUE NONCLUSTERED (pid ASC)WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE =

15、OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON PRIMARY) ON PRIMARY TEXTIMAGE_ON PRIMARYGOALTER TABLE dbo.patinet WITH CHECK ADD CONSTRAINT CK_patinet CHECK (psex=女 OR psex=男)GOALTER TABLE dbo.patinet CHECK CONSTRAINT CK_patinet7.1.4创建病房表在病房表中“病房号”和“病床号”列建立联合主键约束,是每一个病房里的每

16、一个床上只能住着一个病人,“病房号”和“病床号”不能为空值。“病床号”列创建check约束,使得病床号只能在1到3之间,“床位数”列创建check约束,使得床位数只能在1到3之间。创建病房信息表所用到的sql语句:CREATE TABLE dbo.sickroom( sid nchar(10) COLLATE Chinese_PRC_CI_AS NOT NULL, sroomid int NOT NULL, snum nchar(10) COLLATE Chinese_PRC_CI_AS NULL, CONSTRAINT PK_sickroom PRIMARY KEY CLUSTERED (s

17、id ASC, sroomid ASC)WITH (IGNORE_DUP_KEY = OFF) ON PRIMARY) ON PRIMARYGOALTER TABLE dbo.sickroom WITH CHECK ADD CONSTRAINT CK_sickroom CHECK (snum=(1) AND snum=(1) AND sroomid=(3)7.1.5创建治疗表在治疗表中“医生编号”和“病人编号”列建立联合主键约束 “病人编号”和“病人编号”不能为空值;“病人编号”列与doctor表中“病人编号”列建立外键关系,表示两个表之间的联系;“病人编号”列月patinet表中“病人编号”

18、列建立外键关系,表示两表之间的联系。创建治疗情况信息表所用到的sql语句:CREATE TABLE dbo.curecondition( did nchar(10) NOT NULL,pid nchar(10) NOT NULL, pcondition text NULL, ordertype text NULL, mcontent text NULL, curetime datetime NULL, CONSTRAINT PK_curecondition PRIMARY KEY CLUSTERED (did ASC,pid ASC)WITH (PAD_INDEX = OFF, STATIST

19、ICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON PRIMARY) 、ON PRIMARY TEXTIMAGE_ON PRIMARYGOALTER TABLE dbo.curecondition WITH CHECK ADD CONSTRAINT FK_curecondition_doctor FOREIGN KEY(did)REFERENCES dbo.doctor (did)GOALTER TABLE dbo.curecondition CHECK CON

20、STRAINT FK_curecondition_doctorGOALTER TABLE dbo.curecondition WITH CHECK ADD CONSTRAINT FK_curecondition_patinet FOREIGN KEY(pid)REFERENCES dbo.patinet (pid)GOALTER TABLE dbo.curecondition CHECK CONSTRAINT FK_curecondition_patinet7.1.6创建入住表在入住表中“病人编号”、“病房号”和“病床号”列建立主键约束,使每位病人在同一时间内只能有一次入院和出院时间,“病人编

21、号”、“病房号”和“病床号”不能为空值;“病房号”和“病床号”列与sickroom表中“病房号”和“病床号”列建立外键关系,表示两个表之间的联系;“病人编号”列月patinet表中“病人编号”列建立外键关系,表示两表之间的联系。创建入住信息表所用到的sql语句:CREATE TABLE dbo.intake( pid nchar(10) NOT NULL,sid nchar(10) NOT NULL, sroomid int NOT NULL,intaketime datetime NULL, outtime datetime NULL, CONSTRAINT PK_intake PRIMAR

22、Y KEY CLUSTERED (pid ASC,sid ASC,sroomid ASC)WITH (IGNORE_DUP_KEY = OFF) ON PRIMARY) ON PRIMARYGOALTER TABLE dbo.intake WITH CHECK ADD CONSTRAINT FK_intake_patinet FOREIGN KEY(pid)REFERENCES dbo.patinet (pid)GOALTER TABLE dbo.intake WITH CHECK ADD CONSTRAINT FK_intake_sickroom FOREIGN KEY(sid, sroom

23、id)REFERENCES dbo.sickroom (sid, sroomid)GOALTER TABLE dbo.intake WITH CHECK ADD CONSTRAINT CK_Time CHECK (intaketime=outtime) 在sql server 2005中写入以上代码执行,得到如下图7-1中的表。图7-17.2创建视图视图被看成是虚拟表,它并不表示任何物理数据,只是用来查看数据的视窗而已。视图作为一种数据库对象,为用户提供了一种检索数据表中数据的方式,用户可以通过视图浏览数据表中感兴趣的部分或全部数据。7.2.1创建病人基本信息查询视图为了方便查询病人的基本情况

24、,比如查询病人的编号,姓名,性别,缴费情况,病症等,创建了一个基本视图。创建视图所需要的sql语句:CREATE VIEW dbo.View_pcontentASSELECT pid, pname, psex, pmon, illness FROM dbo.patinet7.2.2创建医生信息查询视图为了方便查询医生信息,比如医生编号,姓名,所在科室,这位医生所治疗的病人编号,姓名,病人情况以及有有没有给他开医嘱等等,创建了一个基本视图。创建视图所需要的sql语句:CREATE VIEW dbo.View_dcontentASSELECT dbo.doctor.did, dbo.doctor.

25、dname, dbo.patinet.pid, dbo.patinet.pname, dbo.doctor.office, dbo.curecondition.pcondition, dbo.curecondition.mcontentFROM dbo.doctor INNER JOIN dbo.curecondition ON dbo.doctor.did = dbo.curecondition.did INNER JOIN dbo.patinet ON dbo.curecondition.pid = dbo.patinet.pid7.2.3创建病人入院后情况信息查询视图为了方便了解医生所治

26、疗的病人的基本情况及医生所在科室等,创建一个视图。创建视图所用到的sql语句:CREATE VIEW dbo.View_pincontentASSELECT dbo.patinet.pid, dbo.patinet.pname, dbo.sickroom.sid, dbo.sickroom.sroomid,dbo.intake.intaketime,dbo.intake.outtimeFROM dbo.patinet INNER JOIN dbo.intake ON dbo.patinet.pid = dbo.intake.pid INNER JOIN dbo.sickroom ON dbo.

27、intake.sid = dbo.sickroom.sid AND dbo.intake.sroomid = dbo.sickroom.sroomid7.3创建索引在数据库中为curecondition表建立基于did列和pid列的符合索引did_pid_index。创建索引所用到的sql语句:create index did_pid_indexon curecondition(pid,did)图7-2 did_pid_index索引 7.4创建和执行存储过程存储过程预编译并存储在数据库中的特性,不仅能提高应用效率,确保一致性,更能提高系统执行速度。7.4.1创建并执行插入数据存储过程针对病人

28、信息表patinet,创建一个存储过程p_proc2,执行该存储过程将向数据表patinet中插入一条数据,新纪录的值有参数提供。创建存储过程所用到的sql语句:create proc p_proc2(id nchar(10),nam nchar(10),sex nchar(1),birth datetime,mon text,money float,ill text)asinsert into patinet values(id,nam,sex,birth,mon,money,ill)创建完成后,插入一条数据:execute p_proc2 id=0014,nam=吴丽丽,sex=女,birth=1985-5-14,mon=已缴费,money=1456,ill=白血病得到数据已加入到数据库中。图7-3 插入数据结果 7.4.2创建并执行查询数据存储过程针对病人信息表patinett,创建一个按照性别统计人数的存储过程p_proc3,要求输入性别值后,返回对应性别的病人数,但需保证其在每次被执行时都被重编译处理。创建存储语句所用到的sql语句:create proc p_proc3(in_sex nchar(2),out_num int output)

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1