1、教务管理数据库系统课程设计目录1、需求分析211 信息要求:212 处理要求:213 安全性和完整性要求:214 系统功效设计和划分2第一部分:用户管理部分3第二部分:管理员管理部分32、概念设计32.1概念模型(E-R图):32.2数据字典:5a.数据项5b、数据结构5c、数据流5d、数据存放6e、处理过程62.3 数据流图73、逻辑结构设计73.1 E-R图向关系模型转换(关系码用下横线表出)73.2 设计用户子模式84、物理设计841 选择存取方法842 确定数据库存放结构843 评价物理结构95、系统实施96、运行维护101、需求分析11 信息要求:教务管理系统包含实体有:l 老师工作
2、证号、姓名、职称、电话等;l 学生学号、姓名、性别、出生年月等;l 班级班号、最低总学分等;l 系系代号、系名和系办公室电话等;l 课程课序号、课名、学分、上课时间及名额等。这些实体之间联络以下:l 每个学生全部属于一个班,每个班全部属于一个系,每个老师也全部属于一个系。l 每个班班主任全部由一名老师担任。l 一名老师能够教多门课,一门课能够有几位主讲老师,但不一样老师讲同一门课其课序号是不一样(课序号是唯一)。l 一名同学能够选多门课,一门课可被若干同学选中。l 一名同学选中课若已学完,应该统计有对应成绩。l 本单位学生、老师全部有重名,工作证号、学号能够作为标识。12 处理要求:教学系统关
3、键提供数据维护、选课和信息查询。其中常见查询有:系统中各对象基础信息查询。 查询指定班、系学生信息(名单、人数等)。查询学生成绩、学分情况。查询老师讲课情况和学生选课情况。13 安全性和完整性要求:l 安全性要求:1.系统应设置访问用户标识以判别是否是正当用户,并要求正当用户设置其密码,确保用户身份不被盗用;2.系统应对不一样数据设置不一样访问等级,限制访问用户可查询和处理数据类别和内容;3.系统应对不一样用户设置不一样权限,区分不一样用户,如学生,老师,系统管理员。l 完整性要求:1.多种信息统计完整性,关键信息统计内容不能为空;2.多种数据间相互联络正确性;3.相同数据在不一样统计中一致性
4、。14 系统功效设计和划分依据如上得到用户需求,我们将本系统根据所完成功效分成以下几部分:第一部分:用户管理部分 1、处理用户注册 2、处理用户登录 3、用户能够查询学生信息。 4、用户能够查询快件信息。 5、用户能够提交和查询报修信息。 6、用户能够插入和删除用户自己离返校信息。 7、用户能够修改用户自己密码。第二部分:管理员管理部分各部分完成功效以下: 1、处理管理员登录 2、管理员能够查询学生信息。 3、管理员能够公布和更新快件信息。4、管理员能够插入、修改和查询报修信息。 5、管理员能够插入和查询学生夜归信息。6、管理员能够查询在校和离校学生信息。7、管理员能够修改管理员密码。2、概念
5、设计2.1概念模型(E-R图):老师班级属于最低总学分班号电话职称姓名工作证号学生学号出生年月性别姓名系系办公室电话系名系代号属于工作隶属关系分E-R图1n1n1n学生课程选修学号成绩出生年月性别姓名名额上课时间学分课名课序号mn选修联络分E-R图负责联络分E-R图班级负责最低总学分班号班主任电话职称姓名工作证号11讲课讲课联络分E-R图课程名额上课时间学分课名课序号老师电话职称姓名工作证号1n学生老师系班级课程选修属于属于工作讲课学号成绩出生年月性别姓名名额上课时间学分课名课序号最低总学分班号系办公室电话系名系代号电话职称姓名工作证号负责教务管理系统总E-R图1n1n1n111nmn2.2数
6、据字典:a.数据项编号属性名存放代码类型长度备 注1学号Snochar11学生编号2姓名Snamechar20学生姓名,任意正当字符3性别Ssexchar2学生性别4出生年月Sbirthdate出生时间间接表示年纪5班号Classchar6班级编号6最低总学分TotalCredit浮点数4必需修足学分总数7工作证号Tnochar6老师编号8老师姓名Tnamechar20老师姓名,任意正当字符9职称Titlechar8老师职位称号10电话Telchar11老师联络电话11系代号Dnochar3院系编号12系名Departmentchar10院系名称13系办公室电话Dphonechar11院系办公
7、室工作电话14课序号Cnochar6可区分不一样老师教授同一课程15课名Cnamechar20课程名称16学分Credit浮点数2课程学分17上课时间Ctimedatetime上课时间18名额CnumInt课容量19成绩GradeInt选课学生某门课成绩b、数据结构编号数据结构名组 成1学生学号、姓名、性别、出生年月、所属班级班号2老师工作证号、老师姓名、职称、电话、所在系系号3班级班号、最低总学分、班主任工作证号、所属系系号4系系代号、系名、系办公室电话5课程课序号、课名、学分、上课地点、名额、讲课老师工作证号6选课统计课序号、学号、成绩c、数据流编号数 据 流 名输 入输 出1变更学生信息
8、变更信息学生信息2查询学生信息学号学生信息3变更老师信息变更信息老师信息4查询老师信息工作证号老师信息5变更班级信息变更信息班级信息6查询班级信息班号班级信息7变更系信息变更信息系信息8查询系信息系代号系信息9变更课程信息变更信息课程信息10查询课程信息课序号课程信息11选课选课表变更信息选课信息12查询选课信息学号或课序号选课信息13查询讲课信息工作证号讲课信息d、数据存放数据存放名输入数据流输出数据流说 明 部 分学生信息表修改学生信息学生信息某课程学生信息老师信息表修改老师讲课老师信息班主任信息课程信息表全部开设课程信息学生选择课程信息老师任教课程信息选课表学生全部选课统计学生选课表随机
9、存取 统计学生本学期所选课程信息班级信息表全部班级信息班级基础信息系信息表所设系信息系基础信息e、处理过程处理过程名输入数据流输 出 数 据 流选课选课信息选定课信息登记成绩成绩信息学生所选课程成绩信息修改学生信息更改学生信息修改后学生信息修改老师信息更改老师信息修改后老师信息数据维护各信息表修改信息修改后各信息表2.3 数据流图学生老师选课查询选课表查询查询查询查询登记成绩老师信息选课信息系信息选课信息选课信息选课信息选课信息已选课信息选课信息成绩信息成绩信息系信息班级信息学生信息成绩信息班级信息学生信息课程信息表学生信息表课程信息课程信息课程信息课程信息查询学生信息修改老师信息查询老师信息
10、修改学生信息老师信息表学生信息学生信息老师信息老师信息老师信息系信息表班级信息表查询班级信息系信息班级信息系信息总 数 据 流 图3、逻辑结构设计3.1 E-R图向关系模型转换(关系码用下横线表出)老师(工作证号,姓名,职称,电话,系代号)代码表示:Teacher ( Tno, Tname, Title, Tel, Dno )此为“老师”实体对应关系模式。其中1:n联络“工作”和此关系模式合并,Dno为外码。存在函数依靠为Tno (Tname,Title,Tel,Dno),且不存在多值依靠,所以满足4NF。学生(学号,姓名,性别,出生年月,班号)代码表示:Student ( Sno, Snam
11、e, Ssex, Sbirth, Class )此为“学生”实体对应关系模式。其中1:n联络“属于”和此关系模式合并,Class为外码。存在函数依靠为Sno (Sname,Ssex,Sbirth,Class),且不存在多值依靠,所以满足4NF。系(系代号,系名,系办公室电话)代码表示:Department ( Dno, Dname, Dphone )此为“系”实体对应关系模式。存在函数依靠为Dno (Dname,Dphone),且不存在多值依靠,所以满足4NF。课程(课序号,课名,学分,上课时间,名额,工作证号)代码表示:Course ( Cno, Cname, Credit, Ctime,
12、Cnum, Tno )此为“课程”实体对应关系模式。其中1:n联络“讲课”和此关系模式合并,Tno为外码。存在函数依靠为Cno (Cname,Credit,Ctime,Cnum,Tno),且不存在多值依靠,所以满足4NF。选课(学号,课序号,成绩)代码表示:SC ( Sno, Cno, Grade )此为m:n联络“选修”所对应关系模式。Sno和Cno均为外部码。存在函数依靠为完全函数依靠(Sno,Cno) Grade,且不存在多值依靠,所以满足4NF。班级(班号,最低总学分,工作证号,系代号)代码表示:Class ( Class, TotalCredit, Tno, Dno )此为“班级”实
13、体对应关系模式。其中1:n联络“属于”和1:1联络“负责”和此关系模式合并Tno和Dno为外码。该关系模式中存在传输函数依靠:Class Tno, (Tno Class),Tno Dno,可得Class Dno,故Class 不属于3NF。处理方法是将其模式分解为:Class ( Class, TotalCredit, Tno )和T-D( Tno, Dno),分解后关系模式满足4NF,而且T-D和Teacher码相同,可合并为同一模式。不过考虑到系统要常常进行系学生信息查询,此时就不得不对Student、Class和Teacher三个表进行连接查询,而连接是影响查询效率关键原因,所以取消对C
14、lass模式分解。此时Class关系模式满足2NF。3.2 设计用户子模式为了方便程序查询,建立了以下用户视图:1、某系学生信息视图(学号,姓名,性别,出生年月,班号)2、某系老师信息视图(工作证号,老师姓名,职称,电话,负责班级)3、某课程学生成绩单(学号,姓名,班级,成绩)4、老师讲课信息表(工作证号,老师姓名,职称,教讲课程,学分,上课时间)5、学生已选课表(课序号,课名,学分,讲课老师,上课时间,名额)4、物理设计41 选择存取方法1、数据库管理系统自动在每个表主码上建立索引,通常为B + 树索引。2、在Student表Sname列上建立Stu_name索引,因为查询操作很多全部使经过
15、学生姓名进行。3、在Teacher表Tname列上建立Tea_name索引,因为查询操作很多全部使经过老师姓名进行。42 确定数据库存放结构1、为了提升系统性能,依据具体情况将数据易变部分和稳定部分、常常存取部分和存取频率较低部分分开存放。2、DBMS产品通常全部提供了部分系统配置变量、存放分配参数,依据应用环境确定这些参数值,而且在系统运行时还要依据系统实际运行情况进行调整,以使系统性能最好。43 评价物理结构依据所选择DBMS,如SQL Server ,从定量估算多种方案存放空间、存取时间和维护代价入手,对估算结果进行权衡、比较,选择一个较优合理物理结构。5、系统实施编写关系模式,载入数据
16、。分期分批地组织数据入库,先输入小批量数据做调试用,待试运行基础合格后,再大批量输入数据,逐步增加数据量,逐步完成运行评价。需要注意是,要首先调试运行DBMS恢复功效,做好数据库转储和恢复工作。基础SQL语言代码以下:CREATE SCHEMA TeachAffair AUTHORIZATION GaoCREATE TABLE Department (Dno CHAR(3) PRIMARY KEY, /*列级完整性约束条件,Dno是主码*/ Dept CHAR(20) UNIQUE NOT NULL, Dphone CHAR(11), );CREATE TABLE Teacher (Tno C
17、HAR(6) PRIMARY KEY, /*列级完整性约束条件,Tno是主码*/ Tname CHAR(20) NOT NULL, Title CHAR(8), Tel CHAR(11), Dno CHAR(3), FOREIGN KEY (Dno) REFERENCES Department(Dno) /*表级完整性约束条件,Dno是外码*/ );CREATE TABLE Class (Class CHAR(6) PRIMARY KEY, /*列级完整性约束条件,Class是主码*/ TotalCredit NUMERIC(4,1), Tno CHAR(6), Dno CHAR(3), FO
18、REIGN KEY (Tno) REFERENCES Teacher(Tno), /*表级完整性约束条件,Tno是外码*/ FOREIGN KEY (Dno) REFERENCES Department(Dno) /*表级完整性约束条件,Dno是外码*/ );CREATE TABLE Student (Sno CHAR(11) PRIMARY KEY, /*列级完整性约束条件,Sno是主码*/ Sname CHAR(20) NOT NULL, Ssex CHAR(2), Sbirth DATETIME, Class CHAR(6), FOREIGN KEY (Class) REFERENCES
19、 Class(Class) /*表级完整性约束条件,Class是外码*/ );CREATE TABLE Course (Cno CHAR(6) PRIMARY KEY, /*列级完整性约束条件,Cno是主码*/ Cname CHAR(20) NOT NULL, Credit NUMERIC(2,1), Ctime DATETIME, Cnum SMALLINT, Tno CHAR(6), FOREIGN KEY (Tno) REFERENCES Teacher(Tno) /*表级完整性约束条件,Tno是外码*/ );CREATE TABLE SC (Sno CHAR(11) NOT NULL,
20、 Cno CHAR(6) NOT NULL, Grade SMALLINT CHECK(Grade=0 AND Grade=100), PRIMARY KEY (Sno, Cno), /*主码由两个属性组成,必需作为表级完整性进行定义*/ FOREIGN KEY (Sno) REFERENCES Student(Sno) /*表级完整性约束条件,Sno是外码*/ ON DELETE CASCADE /* 当删除Student表中元组时,级连删除SC表中对应元组*/ ON UPDATE CASCADE, /*当更新Student表中Sno时,级连更新SC表中对应元组*/ FOREIGN KEY
21、(Cno) REFERENCES Course(Cno) /*表级完整性约束条件,Sno是外码*/ ON DELETE NO ACTION /* 当删除Course表中元组造成了和SC表不一致时,拒绝删除*/ ON UPDATE CASCADE, /*当更新Course表中Cno时,级连更新SC表中对应元组*/ );/*DROP TABLE SC;*/*建立索引*/CREATE UNIQUE INDEX Stu_name ON Student(Sname);CREATE UNIQUE INDEX Tea_name ON Teacher(Tname);CREATE UNIQUE INDEX SC
22、no ON SC(Sno ASC, Cno DESC);/*查询某个系(以GIS为例)学生信息*/CREATE VIEW GIS_Student /*建立某个系(以GIS为例)学生信息视图*/ASSELECT *FROM StudentWHERE Class IN (SELECT Class FROM Class WHERE Dname=GIS)WITH CHECK OPTION;SELECT *FROM GIS_Student;SELECT COUNT(*)FROM GIS_Student;/*查询班级学生信息*/SELECT Sno, Sname, Ssex, BirthFROM Stud
23、entWHERE Class = 114072;SELECT COUNT(*)FROM StudentWHERE Class=114072;/*查询学生成绩、学分*/SELECT SC.Cno, Cname, Credit, GradeFROM Course, SCWHERE Sno = 1000500 AND SC.Cno=Course.Cno;SELECT SUM(Credit)FROM SC,CourseWHERE Sno=1000500 AND SC.Cno=Couse.Cno;/*查询老师讲课信息*/SELECT Course.*FROM CourseWHERE Tno=100123
24、;SELECT Student.Sno,Sname,Class,GradeFROM Course,SC,StudentWHERE Tno=100123 AND Course.Cno=SC.Cno AND SC.Sno=Student.Sno;6、运行维护1、针对不一样应用要求制订不一样转储计划,一旦发生故障立即将数据库恢复到某种一致状态,并尽可能降低对数据库破坏;2、依据实际情况修改数据库原有安全性、完整性控制;3、在数据库运行过程中,监督系统运行,对监测数据进行分析,找出改善系统性能方法;4、数据库运行一段时间后,因为统计不停增、删、改,会使数据库物理存放情况变坏,降低数据存取效率,数据库性能下降。这时应按原设计要求重新安排存放位置、回收垃圾、降低指针链等,提升系统性能。当原有数据库设计不能满足新需求,需要重结构数据库,调整数据库模式和内模式。
©2010-2025 宁波自信网络信息技术有限公司 版权所有
客服电话:4008-655-100 投诉/维权电话:4009-655-100