




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、目录1绪论12需求分析13总体设计13.1 功能图13.2安全设计24概念结构设计25逻辑结构设计25.1关系模型转化35.2确定函数依赖、属于第几范式36物理结构设计37数据库的实施、运行47.1创建数据库、建立表4创建数据库yygl4创建医生表5创建病人表5创建病房表6创建治疗表6创建入住表77.2创建视图8创建病人基本信息查询视图8创建医生信息查询视图8创建病人入院后情况信息查询视图87.3创建索引97.4创建和执行存储过程9创建并执行插入数据存储过程9创建并执行查询数据存储过程97.5创建触发器。10创建insert触发器10创建update触发器117.6表中添加信息117.7 进行
2、系统维护13查询病人信息137.7.2 删除病人信息148结论149学习体会14参考文献:14致 谢 141 绪论医院住院部信息管理系统方便医生和病人搜索相关住院信息,并且实现从住院、治疗到出院的全过程精确管理与监控,大幅度减少住院治疗事故,对于常出现医疗和财务纠纷的细节,可以极大地节约成本,提升医院整体效益,赢得长足发展。医院住院部信息管理系统是现代化医院运营的必要技术支撑和基础设施,实现医院住院部信息管理系统的目的就是为了以更现代化、科学化、规范化的手段来加强医院的管理,提高医院的工作效率,改进医院质量,从而树立现代医院的新形象,这也是未来医院发展的必然方向。2 需求分析作为医院住院部这样
3、的的场所,其经济成分比重相对较多,对于患者来说来说主要有住院,缴费等情况。而医院则是针对患者入院后对其进行治疗方面。如何让这么多患者实行分类治疗信息管理正是医院住院部信息系统的目的所在。本系统综合了经济的角度,建立了信息中心,可将来各自患者的信息集中管理,提高医院住院部管理的高效性和有序性,快速反馈了患者信息。从系统开发及实施的可行性和灵活性考虑,本系统的软件开发环境主要选择了当前较为流行的功能强大的 SQL sever 2005 数据库。3 总体设计对数据库进行总体分析设计,掌握所要进行设计的数据库的基本框架,并考虑到数据库的安全完整型的设计。3.1 功能图系统的核心是对住院信息的管理。查询
4、功能也是系统的基本功能。为了实现医院住院部信息管理系统,方便用户和管理与需求,将医院住院部信息管理系统分为:医生管理,病人管理,病房管理,系统维护四个功能模块,如下图3-1。图3-13.2安全设计给数据库中表创建不同的视图,保证数据的安全性,使得不想被人知道的部分信息能够较好地隐藏下来。给数据库中表创建自定义约束,比如check约束、主键约束和唯一键约束,以此来保证数据库的完整性。给数据库创建存储过程和触发器,防止工作人员由于误操作而删掉部分重要信息。4 概念结构设计在需求分析阶段所得到的用户需求抽象为信息结构即概念结构模型的过程就是概念结构设计。它是整个数据库设计的关键。这个部分的关键是设计
5、,一般根据系统要求,画出能反映本系统每个应用需求的 E-R 图。其中包括五个实体即医生实体、病人实体、病房实体、治疗实体、入住实体,以及一些实体与属性之间的联系。然后对初始的 E-R 图进行优化,消除冗余和可能存在的矛盾。根据需要得到一个基本的E-R图,如下图4-1所示。图4-1 医院住院部信息管理系统整体E-R图5 逻辑结构设计逻辑结构的设计的任务就是把概念结构设计阶段设计好的基本E-R模型转换为与选用DBMS产品所支持的数据模型相符合的逻辑结构。5.1关系模型转化医生表(医生编号,姓名,性别,出生日期,职称,科室)病人表(病人编号,姓名,性别,出生日期,缴费情况,缴费金额,病症)病房表(病
6、房号,床位号,床位数)治疗表(医生编号,病人编号,病人情况,医嘱类型,医嘱内容,治疗时间)入住表(病人编号,病房号,床位号,住院时间,出院时间)5.2确定函数依赖、属于第几范式医生表:医生编号姓名,医生编号姓别,医生编号出生日期,医生编号职称,医生编号科室,没有传递依赖,没有部分依赖,则此范式属于第三范式。病人表:病人编号姓名,病人编号姓别,病人编号出生日期,病人编号缴费情况,病人编号缴费金额,病人编号病症,。没有传递依赖,没有部分依赖,则此范式属于第三范式。病房表:(病房号,床位号)床位数,没有传递依赖,没有部分依赖,则此范式属于第三范式。治疗表:(医生编号,病人编号)病人情况,(医生编号,
7、病人编号)医嘱类型,(医生编号,病人编号)遗嘱内容,(医生编号,病人编号)治疗时间,有传递依赖,没有部分依赖,则此范式属于第三范式。入住表:(病人编号,病房号,床位号)住院时间,(病人编号,病房号,床位号)出院时间,有传递依赖,没有部分依赖,则此范式属于第三范式。6 物理结构设计设计中所涉及的表有医生信息表doctor,病人信息表patinet,病房信息表sickroom,治疗情况信息表curecondition,入住信息表intake。表6-1 doctor表列名数据类型宽度允许空值说明列名含义DidNchar10否主键、唯一键职工号DnameNchar16是姓名DsexNchar1是男或女
8、性别DbirthDatetime是出生日期TitleNchar10是职称OfficeNchar10是科室表6-2 patinet表列名数据类型宽度允许空值说明列名含义PidNchar10否主键、唯一键病人编号PnameChar16是姓名PsexNchar1是男或女性别PbirthDatetime是出生日期PmonText是缴费情况PmoneyFloat是缴费金额IllnessText是病症表6-3 sickroom表列名数据类型宽度允许空值说明列名含义SidNchar10否主键病房号SroomidInt否主键、check约束床位号SnumNchar10是 Check约束床位数表6-4 cure
9、condition表列名数据类型宽度允许空值说明列名含义DidNchar10否主键、外键医生编号PidNchar10否主键、外键病人编号PconditionText是病人情况OrdertypeText是医嘱类型McontentText是医嘱内容CuretimeDatetime是治疗时间表6-5 intake表列名数据类型宽度允许空值说明列名含义PidNchar10否主键、外键病人编号SidNchar10否主键、外键病房号SroomidInt否主键、外键病床号intaketimedatetime是入住时间Outtimedatetime是Check约束出院时间7 数据库的实施、运行完成物理结构设计
10、之后,就要用DBMS提供的数据定义语言和其他实用程序将数据库逻辑设计和物理设计结果严格描述出来,成为DBMS可以接受的源代码,再经过调试产生目标文件。7.1创建数据库、建立表经过以上结构设计,使用软件sql server 2005,通过sql语句创建数据库以及以上5个表。创建数据库yygl创建数据库所用到的sql语句:CREATE DATABASE yygl ON PRIMARY ( NAME = Nyygl, FILENAME = ND:库yygl.mdf , SIZE = 3072KB , MAXSIZE = UNLIMITED, FILEGROWTH = 1024KB ) LOG ON
11、( NAME = Nyygl_log, FILENAME = ND:库 yygl_log.ldf , SIZE = 1024KB , MAXSIZE = 2048GB , FILEGROWTH = 10%) COLLATE Chinese_PRC_CI_AS创建医生表在医生表中“医生编号”列建立主键约束,使每个医生编号只代表一名医生,“医生编号”不能为空值;在“性别”列上创建check约束,使“性别”属性的取值只能是男或女二者中的一个,不允许出现第三个;在“医生编号”列唯一性约束,保证职工号的唯一性。创建医生信息表所用到的sql语句:CREATE TABLE dbo.doctor(did nc
12、har(10) NOT NULL,dname nchar(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 PR
13、IMARY,CONSTRAINT uq_key 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.d
14、octor CHECK CONSTRAINT CK_doctor创建病人表在病人表中“病人编号”列建立主键约束,是每一个病人编号都代表着一个病人,“病人编号”不能为空值;在“性别”列上创建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,p
15、money float NULL,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
16、_NORECOMPUTE = 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创建病房表在病房表中“病房号”和“病床号”列建立联
17、合主键约束,是每一个病房里的每一个床上只能住着一个病人,“病房号”和“病床号”不能为空值。“病床号”列创建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
18、CLUSTERED (sid 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<=(3)ALTER TABLE dbo.sickroom WITH CHECK ADD CONSTRAINT CK_sickroom_1 CHECK (sroomid>=(1) AND sroomid<=(3)创建治疗表在治疗表中
19、“医生编号”和“病人编号”列建立联合主键约束 “病人编号”和“病人编号”不能为空值;“病人编号”列与doctor表中“病人编号”列建立外键关系,表示两个表之间的联系;“病人编号”列月patinet表中“病人编号”列建立外键关系,表示两表之间的联系。创建治疗情况信息表所用到的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
20、NULL, CONSTRAINT PK_curecondition PRIMARY KEY CLUSTERED (did ASC,pid ASC)WITH (PAD_INDEX = OFF, STATISTICS_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_cu
21、recondition_doctor FOREIGN KEY(did)REFERENCES dbo.doctor (did)GOALTER TABLE dbo.curecondition CHECK CONSTRAINT 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 C
22、ONSTRAINT FK_curecondition_patinet创建入住表在入住表中“病人编号”、“病房号”和“病床号”列建立主键约束,使每位病人在同一时间内只能有一次入院和出院时间,“病人编号”、“病房号”和“病床号”不能为空值;“病房号”和“病床号”列与sickroom表中“病房号”和“病床号”列建立外键关系,表示两个表之间的联系;“病人编号”列月patinet表中“病人编号”列建立外键关系,表示两表之间的联系。创建入住信息表所用到的sql语句:CREATE TABLE ake(pid nchar(10) NOT NULL,sid nchar(10) NOT NULL,s
23、roomid int NOT NULL,intaketime datetime NULL,outtime datetime NULL, CONSTRAINT PK_intake PRIMARY KEY CLUSTERED (pid ASC,sid ASC,sroomid ASC)WITH (IGNORE_DUP_KEY = OFF) ON PRIMARY) ON PRIMARYGOALTER TABLE ake WITH CHECK ADD CONSTRAINT FK_intake_patinet FOREIGN KEY(pid)REFERENCES dbo.patinet (p
24、id)GOALTER TABLE ake WITH CHECK ADD CONSTRAINT FK_intake_sickroom FOREIGN KEY(sid, sroomid)REFERENCES dbo.sickroom (sid, sroomid)GOALTER TABLE ake WITH CHECK ADD CONSTRAINT CK_Time CHECK (intaketime<=outtime) 在sql server 2005中写入以上代码执行,得到如下图7-1中的表。图7-17.2创建视图视图被看成是虚拟表,它并不表示任何物理数据,只是用
25、来查看数据的视窗而已。视图作为一种数据库对象,为用户提供了一种检索数据表中数据的方式,用户可以通过视图浏览数据表中感兴趣的部分或全部数据。7.2.1创建病人基本信息查询视图为了方便查询病人的基本情况,比如查询病人的编号,姓名,性别,缴费情况,病症等,创建了一个基本视图。创建视图所需要的sql语句:CREATE VIEW dbo.View_pcontentASSELECT pid, pname, psex, pmon, illness FROM dbo.patinet7.2.2创建医生信息查询视图为了方便查询医生信息,比如医生编号,姓名,所在科室,这位医生所治疗的病人编号,姓名,病人情况以及有有
26、没有给他开医嘱等等,创建了一个基本视图。创建视图所需要的sql语句:CREATE VIEW dbo.View_dcontentASSELECT dbo.doctor.did, dbo.doctor.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.
27、did INNER JOIN dbo.patinet ON dbo.curecondition.pid = dbo.patinet.pid7.2.3创建病人入院后情况信息查询视图为了方便了解医生所治疗的病人的基本情况及医生所在科室等,创建一个视图。创建视图所用到的sql语句:CREATE VIEW dbo.View_pincontentASSELECT dbo.patinet.pid, dbo.patinet.pname, dbo.sickroom.sid, dbo.sickroom.sroomid,aketime,ake.outtimeFROM db
28、o.patinet INNER JOIN ake ON dbo.patinet.pid = ake.pid INNER JOIN dbo.sickroom ON ake.sid = dbo.sickroom.sid AND ake.sroomid = dbo.sickroom.sroomid7.3创建索引在数据库中为curecondition表建立基于did列和pid列的符合索引did_pid_index。创建索引所用到的sql语句:create index did_pid_indexon curecondition(pid,did)图7
29、-2 did_pid_index索引 7.4创建和执行存储过程存储过程预编译并存储在数据库中的特性,不仅能提高应用效率,确保一致性,更能提高系统执行速度。创建并执行插入数据存储过程针对病人信息表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 patine
30、t 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 插入数据结果 创建并执行查询数据存储过程针对病人信息表patinett,创建一个按照性别统计人数的存储过程p_proc3,要求输入性别值后,返回对应性别的病人数,但需保证其在每次被执行时都被重编译处理。创建存储语句所用到的sql语句:create proc p_proc3(in_sex nchar
31、(2),out_num int output)with recompileasbeginif in_sex=男select out_num=count(psex)from patinet where psex=男elseselect out_num=count(psex)from patinet where psex=女end创建完成后,查询一下医院里住院的女病人的个数:declare man_num intexec p_proc3 女,man_num outputselect man_num得到如下图7-4所示的结果:图7-47.5创建触发器。触发器是一种专用类型的存储过程,它被绑定到数据表
32、或者视图上,通过事件进行触发。触发器的主要作用是实现由主键和外键所不能保证的复杂的参照完整性和数据一致性。创建insert触发器针对病人信息表patinet,创建一个触发器p_tri1,当向表patinet中插入一条记录时,自动显示表patinet中的记录。创建触发器所用到的sql语句:create trigger p_trion patinetfor insertasselect * from patinetinsert into patinet values(0015,艾静,女,1988-6-2,已缴费,1586,坏死)运行语句得到的结果如下图7-5显示在结果栏中:图7-5创建update触发器针对病人信息表patinet,创建一个触发器p_tri2,该触发器将在修改时被触发,该触发器不允许修改表的did列。创建触发器所用到的sql语句:create trigger p_tri2on patinetfor updateasif update(pid)beginraiserror (您不能修改病人编号,否则会造成记录混乱',10,1)rollback transactionend修改0001号病人的编号为0019,输入一下sql语句:update patinet set pid='0019' where pi
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 苗木供销种植合同协议
- 药厂采购山药合同协议
- 蔬菜瓜果购销合同协议
- 菜籽秸秆销售合同协议
- 衬砌工程分包合同协议
- 宁波信息技术试题及答案
- 茶叶出口销售合同协议
- 英语加盟权转让合同协议
- 装修家具公司合同协议
- 药品卖买合同协议书范本
- 新三板、北京交易所简介及上市利弊分析
- 化学实验室5S管理
- 桥梁安全隐患排查
- 2023年《计量经济学》期末试卷
- 2025年高考历史必背的228个知识点
- 2024年广东卷地理高考试卷(原卷+答案)
- 大学生职业生涯规划与就业创业指导(四川水利职业技术学院)知到智慧树答案
- 山东师大附中2025届高考英语一模试卷含解析
- 海洋能建结构优化
- JJF(浙) 1126-2016 风速变送器校准规范
- 七年级历史下册 第一单元 隋唐时期繁荣与开放的时代 第2课 从贞观之治到开元盛世教学设计2 新人教版
评论
0/150
提交评论