版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
实例2:教室管理系统数据库设计1数据库设计1。1需求设计1.1。1引言在大学里,教室仍然是教学的主要场所,也是学生学习的重要场所,所以教室环境和设备直接影响到教学活动的开展和学生的学习。为了保证教室环境良好的运转,教室的管理也就显得十分的必要和重要。但是教室的管理也并不是一件很容易的事情。教室设备(尤其是多媒体设备)有所损坏必须及时登记,修复,否则很可能影响以后教学,造成教学事故.教室的使用具有一定的计划性和流动性,即一个班在相应的时间里,所上的课程和使用的教室是固定的,但是不同的课程在不同的时间里会使用不同的教室,这与教务处的课程安排是密切相关的。尤其是使用多媒体教室的时候,这就显得比较麻烦。为了能够更系统的,更有序的,更合理的,更有效的进行教室管理,有必要利用计算机来处理各种信息,这也就需要一个更有效的教室管理系统。为此,经过较详细的调查和慎重的思考,我决定做一个教室管理系统,来解决这些问题,使管理简化,方便而且更有效。1。1。2目标与任务(1)目标充分了解用户的需求,了解工作的流程,以及可能出现的问题.(2)任务处理对象:本系统总体上说涉及了三个方面的数据,职工的信息,教室的信息,课程的信息,其中职工信息包括了员工信息和清洁工信息.此外还有值班安排信息,多媒体设备损坏纪录,常规设备损坏纪录。处理功能要求:教室管理系统的具体功能包括三个方面:教室查询子系统,卫生管理子系统,设备管理子系统。教室查询子系统主要完成空闲教室查询(无课教室),教室使用查询的功能;卫生管理子系统主要完成值班安排与修改功能和值班情况记录的功能;设备管理子系统比较麻烦,主要是接收损坏信息,通过检查其有效性,把有效的损坏信息分类并且记录,然后通知维修工,再纪录维修情况的功能。(3)安全性和完整性要求数据项名数据项含义说明数据类型长度取值范围取值含义于其他数据项的逻辑关系数据项之间的联系在这个系统中涉及到了相关人员的问题,而且同一个职工可能在不同的表中存在,要考虑到,如果辞退或者某职工辞职,那么不仅要在职工信息表中删除相应的信息 ,还要在其他的相关表中删除信息,这就涉及到了安全性的问题,初步打算用一个触发器来解决这个问题。完整性也是一个重要的内容,它也涉及安全性上的问题。1.1.3阶段结果(1)用户调查本系统的用户范围比较广,教室查询子系统主要针对学生,通过听取周围学生的看法和意见,以及自身的体会,比较充分的了解了学生的需求;卫生管理子系统主要针对教室管理的员工及其主任,我直接询问了相关的员工,通过对他们的询问,了解了他们的工作的基本流程,及其需求;设备管理子系统主要针对,教室管理的员工和维修工,通过对员工的咨询,了解了他们管理的工作流程和具体的需求。(2)业务流程图详见附录1(3)数据流程图下面是一个设备流程图的底层流程图:其它的详见附录2(4)数据字典数据项:表1教室信息数据项数据项名数据项含义说明数据类型长度取值范围取值含义于其他数据项的逻辑关系数据项之间的联系Spart校区char10Rname教室名称char10Position所在位置char20Type教室类型char10Room容量int4
Cno课程号char10Cname课程名称char20Ctime课程学时int4Weed周次char10Day星期char10Node节次char20Rname教室名称char10Mno系号char10Mname系名char20cg班级char20Number人数int4表2课程信息数据项表3职工信息数据项数据项名数据项含义说明数据类型长度取值范围取值含义于其他数据项的逻辑关系数据项之间的联系Pno职工编号char10等于维修工编号Pname姓名char20等于维修工姓名Sex性别char4Age年龄int4Jname职业名称char10Addr住址char40Tel联系电话char20Week周次char10Day星期char10Ontime上班时间char20Uptime下班时间char20表4损坏信息数据项数据项名数据项含义说明数据类型长度取值范围取值含义于其他数据项的逻辑关系数据项之间的联系Rname教室名称char10Dlevel损坏程度char10Mend修复难易char10Mno维修工编号char10等于维修工编号
MnameRepair维修工姓名是否修复charchar1010等于维修工姓名1。1.4数据结构表5数据结构表数据结构名含义说明组成Class(T1)教室信息校区名,教室名称,所在位置,教室类型,容量Course(T2)Worker(Dl)Duty(D2)State(D3)Media(Pl)Routine(P2)课程信息职工信息值班值班情况记录多媒体设备损坏记录常规设备损坏记录课程号,课程名称,周次,星期,节次,课程学时,教室名称,系号,系名,班级,人数职工编号,姓名,职业名称,性别,年龄,住址,联系电话职工编号,姓名,职业名称,星期,上班时间,下班时间职工编号,姓名,职业名称,星期,周次教室名称,损坏程度,修复难易,维修工编号,维修工姓名,是否修复教室名称,损坏程度,维修工编号,维修工姓名,是否修复1。1.5处理逻辑描述(1)教室查询子系统输入:查询条件输出:查询结果处理:按照条件,在相应的表中,查找相应的数据,然后输出(1)卫生管理子系统输入:查询、插入或修改的目标结果:输出查询的结果,或者插入成功,或者修改成功处理:在相应的表中完成相应的操作.(3)设备管理子系统输入:插入或修改或查询的条件或目标结果:输出查询结果或插入成功或修改成功处理:在相关表中完成相关的操作。1.2概念设计1。2。1引言概念结构的实际是整个数据库设计的关键,这个阶段主要的目标是通过对用户需求进行综合、归纳与抽象,形成一个独立于DBMS的概念模型(E-R图).它的主要特点是:1.能真实、充分地反映现实世界,包括事物与事物之间的联系,能满足用户对数据的处理要求,是对现实世界的一个真实模型;2.易于理解,因此可以用它和不熟悉计算机的用户交换意见;3。易于更改,当应用环境和应用要求改变时,容易对概念模型修改和扩充;4。易于向关系、网状、层次等各种数据模型转换.1.2。2概念模型设计(1)设计E—R图详见附录31.2。3实体的属性、联系的属性主码表示如:教室名称;外码表示如:教室名称;普通属性如:教室名称。教室(校区名,教室名称,所在位置,教室类型,容量);课程(课程号,教室名称,课程名称,周次,星期,节次,课程学时,系名,班级,人数);职工(职工编号,姓名,职业名称,性别,年龄,住址,联系电话);多媒体设备损坏(教室名称,维修工编号,损坏程度,修复难易,维修工姓名,是否修复,备注);常规设备损坏(教室名称,维修工编号,损坏程度,维修工姓名,是否修复 ,备注);值班信息(职工编号,姓名,职业名称,星期,上班时间,下班时间);值班记录(职工编号,姓名,职业名称,星期,周次);1.3逻辑设计1.3。1引言这个阶段的任务就是把概念结构设计阶段设计好的基本E—R图转换为与DBMS所支持的数据模型相符合的逻辑结构。在这个阶段里,该系统的目标就是把基本的E-R图转换成关系数据模型。1.3。2数据组织(1)将E-R图转换成关系模型:E-R图转换成关系模型应该遵循以下原则:一个实体型转换为一个关系模式。一个1:1联系可以转换为一个独立的关系模式,也可以与任意一端对应的关系模式合并。3。 把一个1:n联系转换为一个独立的关系模式。一个m:n联系转换为一个关系模式。三个或三个以上实体间的一个多元联系可以转换为一个关系模式。具有相同码的关系模式可合并。(2)转换的结果:主码表示如:教室名称;外码表示如:教室名称;普通属性如:教室名称。教室(校区名,教室名称,所在位置,教室类型,容量);课程(课程号,教室名称,课程名称,教师编号,周次,星期,节次,课程学时,系名,班级,人数);职工(职工编号,姓名,职业名称,性别,年龄,住址,联系电话);多媒体设备损坏(教室名称,维修工编号,损坏程度,修复难易,维修工姓名,是否修复,备注);常规设备损坏(教室名称,维修工编号,损坏程度,维修工姓名,是否修复,备注);值班信息(职工编号,姓名,职业名称,星期,上班时间,下班时间);值班记录(职工编号,姓名,职业名称,星期,周次);该模式没有插入异常,删除异常等操作异常现象,已经达到3NF。(3)设计用户子模式:鉴于安全问题,每一个表都应有相应的视图。建立相关的视图如下:教室视图:Class1(校区,教室名称,地点,教室类型,容量);课程与教室视图:Course1(校区,教室名称,教室类型,课程名称,周次,星期,节次,容量);这两个视图包含了允许学生和员工等用户查询的属性,不允许修改,插入和删除。为职工做视图:值日视图:Dutyl(职工编号,职工姓名,职业名称,上班时间,下班时间);清洁工值班记录:State1(职工编号,职工姓名,职业名称,日期,情况);员工值班记录:State2(职工编号,职工姓名,职业名称,日期,情况);职工视图:State3(职工编号,职工姓名,职业名称,日期,情况);常规设备损坏纪录:Routine1(教室名称,职工编号,职工姓名,描述,是否修复,日期,备注);多媒体设备损坏:Medial(教室名称,职工编号,职工姓名,描述,修复难易,是否修复,日期,备注);职工信息:Workerl(职工编号,姓名,职业名称,性别,年龄,住址,联系电话);在这些视图中,值日视图允许各个职工查询,但只允许管理员(主任)进行修改,插入,删除等操作;清洁工值班记录视图,除维修工外,其他各职工都可查询,员工还可进行修改操作,管理员(主任)可进行各种操作;员工值班记录只允许员工查询;常规设备损坏纪录视图允许员工和维修工进行查询,员工只对视图中的教室名称属性有修改,插入的权限,维修工对其他属性有修改权限;在多媒体设备损坏信息视图中,允许员工和多媒体维修工进行查询,员工只对教室名称有修改和插入的权限,多媒体维修工对其他的属性有修改权限。为方便,其中的部分权限在制作过程中要直接赋给基本表。1。3.3数据处理见系统的功能模块图:1.4物理设计1。4.1引言数据库在物理设备上的存储与存取方法称为数据库的物理结构,它依赖于给定的计算机系统。为一个给定的逻辑数据模型选取一个最适合应用要求的物理结构的过程,就是数据库的物理设计。1.4.2目标与任务对数据库进行合理的物理设计,以提高其时间和空间效率。(l)数据存取方面确定数据库的物理结构,在关系数据库中主要指存取方法和存储结构;对物理结构进行评价,评价的重点是时间和空间效率。如果评价结果满足原设计的要求,则可以进入到物理实施阶段,否则就需要重新设计或修改物理结构,有时甚至要返回逻辑设计阶段修改数据模型。(2)功能模块见图15所示1.5数据库实施1。5。1建立基本表/*建立教室信息表*/createtableClass(Spart char(10),
Rnamechar(10)notnullunique,RnamePositionchar(20),Type char(10),Room int,primarykey(Rname))/*建立课程信息表*/createtableCourse(Cnochar(10),Cnamechar(20),Rnamechar(10),Cweekchar(10),Cdaychar(10),Nodechar(10),Ctimeint,Gradechar(10),Roomint,Numberint,Sdeptchar(20))/*建立职工信息表*/createtableWorker(Wno char(10)notnullunique,Wname char(20),Wsex char(4),Wage int,Jname char(10),Addr char(40),Tel char(20),primary key(Wno),check(Wage〉=18andWage<=60))/*建立值班信息表*/createtableDuty(Wno char(10),JnameWname char(20),Jnamechar(10),
Ontimechar(20),Uptimeprimarychar(20),key(Wno),foreignkey(Wno)references Worker(Wno),)/*建立值班情况记录表*/createtableState(Wnochar(10),Wnamechar(20),Jnamechar(10),Wdatechar(20),statechar(20))/*建立多媒体设备损坏记录表*/createtableMedia(Rnamechar(10),Wnochar(10),Wnamechar(20),Describechar(20),Dlevelchar(10),Repairchar(4),Mdatechar(20),Pmarkchar(50))/*建立常规设备损坏记录表*/createtableRoutine(Rnamechar(10),Wnochar(10),Wnamechar(20),Describechar(20),RepairMdatechar(4),char(20),Pmarkchar(50))1.5。2建立视图/*教室信息视图*/createviewClass1(校区,教室名称,地点,教室类型,容量)asselect *from Class/*课程信息视图*/createviewCourse1(校区,教室名称,教室类型,课程名称,周次,星期 ,节次,容量)asselectClass。Spart,Class.Rname,Type,Cname,Cweek,Cday,Node,Class.RoomfromClass,CourseWhereClass。Rname=Course.Rname/*职工信息视图*/createviewWorker1(职工编号,姓名,职业名称,性别,年龄,住址,联系电话)asselect*fromWorker/*值班信息视图*/createviewDuty1(职工编号,职工姓名,职业名称,上班时间,下班时间)asselect *from Duty/*清洁工值班情况记录视图*/createviewState1(职工编号,职工姓名,职业名称,日期,情况)asselect *from Statewhere Jname ='清洁工'/*除清洁工外其他职工值班情况视图*/createviewState2(职工编号,职工姓名,职业名称,日期,情况)asselect *from Statewhere Jname !='清洁工'/*总的职工值班情况视图*/createviewState3(职工编号,职工姓名,职业名称,日期,情况)asselect*fromState/*常规设备损坏视图*/createviewRoutine1(教室名称,职工编号,职工姓名,描述,是否修复,日期,备注)asselect*fromRoutine/*多媒体设备损坏视图*/createviewMedia1(教室名称,职工编号,职工姓名,描述,修复难易,是否修复,日期,备注)asselect*fromMedia2.5。3查询与更新/*员工课程查询*/createProcedurejs_kc1@C_Spart char(10),@C_Cweek char(6),@C_Cday char(4),@C_Node char(5)asselect 校区,教室名称,课程名称,教室类型,容量fromCourse1where 校区=@C_Spartand周次=@C_Cweekand星期=@C_Cdayand节次=@C_Nodeand教室类型='多媒体教室'orderby教室名称ASC/*学生课程查询*/createprocedurejs_kc2@C_Spart char(10),@C_Cweek char(6),@C_Cday char(4),@C_Node char(5)asselect 校区,教室名称,课程名称,教室类型,容量fromCourse1where 校区=@C_Spartand周次=@C_Cweekand星期=@C_Cdayand节次=@C_Nodeorderby教室名称ASC/*空教室查询*/createprocedurejs_kjs1@C_Spart@C_Cweek@C_Cday@C_Nodeaschar(10),char(6),char(4),char(5)select校区,教室名称,教室类型,容量fromClass1wherenotexistsselectfromCourse1where校区=@C_Spartand周次=@C_Cweekand星期=@C_Cdayand节次=@C_Nodeand教室名称=Class1。教室名称)/*职工值班查询*/createprocedurejs_zb1@S_Wnochar(10)asselect 职工编号,职工姓名,职业名称,上班时间,下班时间fromDuty1where 职工编号=@S_Wno/*职工值班记录查询*/createprocedurejs_zbjl1@S_Wnochar(10)asselect职工编号,职工姓名,职业名称,日期,情况fromState3where职工编号=@S_Wno/*员工对清洁工值班记录的插入(视图)*/createprocedurejs_zlc1@S_Wno char(10),@S_Wnamechar(20),@S_Jname char(10),@S_Wdate char(20),@S_statechar(20)asinsertintoState1values(@S_Wno,@S_Wname,@S_Jname,@S_Wdate,@S_state)/*员工对清洁工值班记录的删除(视图)*/createprocedurejs_zls1@S_Wnochar(10)asdeletefromState1where职工编号=@S_Wno/*主任除清洁工外的其他职工值班记录的插入(视图)*/createprocedurejs_zlc2@S_Wno char(10),@S_Wname char(20),@S_Jname char(10),@S_Wdate char(20),@S_statechar(20)asinsertintoState2values(@S_Wno,@S_Wname,@S_Jname,@S_Wdate,@S_state)/*主任除清洁工外的其他职工值班记录的删除(视图)*/createprocedurejs_zls2@S_Wnochar(10)asdeletefromState2where 职工编号=@S_Wno/*主任对职工信息表的插入*/createprocedurejs_zlc3@W_Wnochar(10),@W_Wnamechar(20),@W_Wsex char(4),@W_Wage int,@W_Jnamechar(10),@W_Addr char(40),@W_Telchar(20)asinsertintoWorkervalues(@W_Wno,@W_Wname,@W_Wsex,@W_Wage,@W_Jname,@W_Addr,@W_Tel)/*用游标完成的主任对职工信息表的修改*/CREATEPROCEDUREjs_dmtxg1@W_Wnochar(10),@W_Wnamechar(20),@W_Wsex char(4),@W_Wageint@W_Wageint,@W_Jnamechar(10),@W_Addr char(40),@W_Telchar(20)ASDECLAREaddWorkerCURSORSTATICFORselect*fromWorkerwhereWno=@W_WnoandWname=@W_WnameandWsex=@W_WsexandWage=@W_WageandJname=@W_JnameandAddr=@W_AddrandTel=@W_TelOPENaddWorkerIF@@CURSOR_ROWS〉0UPDATEWorkersetWno=@W_WnoandWname=@W_WnameandWsex=@W_WsexandWage=@W_WageandJname=@W_JnameandAddr=@W_AddrandTel=@W_TelwhereWno=@W_WnoELSEinsertintoWorker(Wno,Wname,Wsex,Wage,Jname,Addr,Tel)values(@W_Wno,@W_Wname,@W_Wsex,@W_Wage,@W_Jname,@W_Addr,@W_Tel)CLOSEaddWorkerDEALLOCATEaddWorker/*主任对职工信息表的删除*/createprocedurejs_zls3@W_Wnochar(10)asdeletefromWorkerwhere Jname=@W_Wno/*员工对多媒体设备损坏纪录的插入*/createprocedurejs_dmtcr1@M_Rnamechar(10),@M_Wno char(10),@M_Wnamechar(20),@M_Describechar(20),@M_Dlevel char(10),@M_Repair char(4),@M_Mdate char(20),@M_Pmarkchar(50)asinsertintoMediavalues(@M_Rname,null,null,null,null,null,null,null)/*多媒体维修工对多媒体损坏纪录的修改*/CREATEPROCEDUREjs_dmtxg1@M_Rname char(10),
@M_Wnochar@M_Wnamechar20),@M_Describechar20),@M_Dlevelchar(10),@M_Repairchar(4),@M_Mdatechar(20),@M_Wnochar@M_Wnamechar20),@M_Describechar20),@M_Dlevelchar(10),@M_Repairchar(4),@M_Mdatechar(20),@M_Pmarkchar(50)asdeletefromMediawhereRname=@M_RnameandWno=nullwhereinsertintoMediavalues(@M_Rname,@M_Wno,@M_Wname,@M_Describe,@M_Dlevel,@M_Repair,@M_Mdate,@M_Pmark)/*员工对多媒体设备损坏纪录的插入*/createprocedurejs_dmtcr2@M_Rnamechar@M_Wnochar10),@M_Wnamechar20),@M_Describe@M_Rnamechar@M_Wnochar10),@M_Wnamechar20),@M_Describechar20),@M_Repairchar(4),@M_Mdatechar(20@M_Mdatechar(20),@M_Pmark@M_Pmarkchar(50)asinsertintoRoutinevalues(@M_Rname,null,null,null,null,null,null)/*维修工对常规损坏纪录的修改*/CREATEPROCEDUREjs_dmtxg2@M_Rnamechar(10),@M_Wno@M_Rnamechar(10),@M_Wnochar(10),@M_Wname@M_Wnamechar(20),@M_Describechar(20),@M_Repairchar4),@M_Mdatechar20),@M_Pmark@M_Describechar(20),@M_Repairchar4),@M_Mdatechar20),@M_Pmarkchar50)asdeletefromRoutinewhereRname=@M_RnameandWno=nullwhereinsertintoRoutinevalues(@M_Rname,@M_Wno,@M_Wname,@M_Describe,@M_Repair,@M_Mdate,@M_Pmark)1。5。4建立触发器/*建立职工信息表触发器*/CREATETRIGGERjs_zgONdbo。WorkerFORDELETEASdeleteDutyfromdeleted whereDuty.Wno=deleted.WnodeleteStatefromdeletedwhereState。Wno=deleted.Wno2数据库调试与试运行由于内容较多,这里只调试和运行一部分。建立基本表、导入数据和建立视图比较简单,这里就不再显示,下面调试查询与更新。2.1查询/*学生课程查询*/createprocedurejs_kc2@C_Spart char(10),@C_Cweek char(6),@C_Cday char(4),@C_Node char(5)asselect 校区,教室名称,课程名称,教室类型,容量fromCourse1where 校区=@C_Spartand周次=@C_Cweekand星期=@C_Cdayand节次=@C_Nodeorderby教室名称ASC调试:输入:js_kc2'北校区','第一周','周1',‘1—2节
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 云南省景洪市第三中学2014-2021学年高一上学期期末考试数学试题
- 2022版《红对勾讲与练》高三物理人教版总复习课时作业13万有引力与航天-
- 饲料加工工艺
- 处理意见书范文处理意见写
- 磨削加工技术
- 天津华宁KTC101系统说明书
- 铝冶炼与节能减排政策实施效果考核试卷
- 节能建筑室内空气质量控制施工考核试卷
- 医疗污水深度处理技术-洞察分析
- 异黄樟素污染源及风险评估-洞察分析
- 幼儿园小班语言《谁的耳朵》课件
- 院前急救诊疗技术操作规范
- 患者转诊记录单
- 美好生活“油”此而来-暨南大学中国大学mooc课后章节答案期末考试题库2023年
- 买卖合同纠纷案民事判决书
- 神经内科应急预案完整版
- 2023零售药店医保培训试题及答案篇
- UCC3895芯片内部原理解析
- 混凝土设计的各种表格
- 保安员培训教学大纲
- 广东省高等学校“千百十工程”第六批继续培养对象和第
评论
0/150
提交评论