1、数据库原理课程大作业网上选课系统数据库设计数据库原理课程大作业数据库设计课题名 称: 网上选 课系统数据 库设计学 号:姓 名:专业年级:成 绩:日 期:网上选课系统数据库设计目录1绪论 .12应用系统功能分 析 .22.1业务操作流 程 .22.2系统功能设 计 .23数据库设 计 .23.1需求分析 .33.2概念结构设 计 .53.3逻辑结构设 计 .73.4物理结构设计与实 施 .84结束语 .94.1收获和体 会 .94.2总结与展 望 .10网上选课系统数据库设计1绪论随着科学技术的发展,计算机已经运用到很多方面,网上选课在各个高校已经不可或缺。信息的自动处理以及网络式的信息交互方
2、式已经被人们广泛应用,使的办公更加的方便快捷和人性化。网上选课系统种类繁多,只有一个稳定高效的选课系统才能真正的为我们带来方便。教学计划必需随着社会和科技的不断地而进行修订,使得学校安排学生选课、排课的任务日趋繁琐、复杂。简化选课难度,提高选课质量势在必行。目前,各高校已相继建成了覆盖全校的高速校园网,并与 Internet 互联,具备了通过网络来管理教学的硬件环境。传统的人工选课方法在流程上存在很多弊端,全部由人工完成,工作量太大,有时会出现错误。对学生来说选课不方便信息不灵活,可能会选错或者选课与上课时间有冲突,等都不利于选课的开展。而且老师对学生的录入,成绩管理发放更不方便。因此为了进一
3、步提高学生选课管理的效率,保证学院学生选课工作的顺利有序进行,信息化和网络化的推行也是正被广泛应用并被实践证明是目前最有效的途径。为了方便广大师生,我们需要运用所学自己设计一种网上选课系统数据库软件用来管理好选课信息。选课系统将使选课管理更加规范,提高信息管理的速度和准确性。2应用系统功能分析本系统为三类用户使用:系统管理员,老师和学生。因此应当具有的功能:可让管理理员对学生信息,老师信息,课程信息,教室信息进行有效的管理,包括增加、删除、查询、修改等基本维护功能。可让管理员和教师对特定班级进行必修课的设定。可让学生在满足选修学分的情况下进行自由选课。可让教师对特定的班级及个人的科目进行评分。
4、综合查询可让学生查看自己的选课情况,让老师查看教务安排。2.1 业务操作流程本系统管理员和所有者拥有最高权限。能对学生和老师的信息进行维护,所有教室、课程的信息维护有管理员完成,信息的维护包括增加,删除,查询,修改等功能。学生所选科目分必修和选修,必修课程可由教师及管理员设定,选修课由学生自己选。学生可查询自己的选课情况和学习情况,老师可以给学生的考试情况打分。进入系统需要身份验证,学生和老师可修改自己的密码,管理员拥有修改所有用户的权限。2.2 系统功能设计(1)系 统管理员1网上选课系统数据库设计维护学生与教师个人信息:通过此项功能可以实现对教师和学生的个人信息添加删除修改。维护课程、教室
5、信息:通过此项功能可以实现对课程,教室的综合信息进行增加删除修改。(2)教 师用户1)显示和修改个人信息:教师用户登录系统后,可以查看和修改教师的个人信息,如姓名,电话, E-mail 地址、登陆密码等。2)给学生分数:课程结束后,教师用户登录系统,可以为学过课程的学生给予相应的成绩,若及格,给予学生学分。3)综合查询:查看部分教师的教务安排,包括上课时间,授课地点,所用教材等信息(3)学 生用户1)维护个人信息:学生登录系统后,可以查看和修改学生的个人信息,如姓名,性别,电话、账户密码等。2)查看自己选课信息:学生登录系统后通过综合查询能够查看自己的必修课和选修课的信息,包括查看学习成绩等3
6、)选择自己的选修课程。3数据库设计考虑数据库及其应用系统开发全过程,将数据库设计分为六个阶段包括:需求分析,概念结构设计,逻辑结构设计,物理结构设计,数据库实施和数据库运行与维护。通过对选课系统的管理最终需要实现的功能分析,构建数据字典,处理相应的数据,然后将数据抽象为具体的DBMS概念模型,画出全局 ER模型,并分析各个实体之间的关系,将概念模型结构转化为数据模型,再进行适当的优化。选取合适的存储结构和存取方法,建立选课系统数据库。在对数据库进行试运行和维护,分析改善数据库,丙丁是的进行功能维护,使其能高效的运行,为广大的师生提供方便和服务。3.1 需求分析随着信息时代科技不断提高 , 学校
7、规模不断扩大 , 教学质量不断提高 , 大学期间有许多公共选修课 , 以往的选修课方法是课堂报名或者纸上填写方式报名 , 这种方法虽然直接 , 但是造成选课的盲目性 , 而且学生选过课程后不好在更改查看 , 一方面浪费大量的人力,物力资源 , 另一方面浪费时间以及在认为统计过程中不可避免的出现差错的情况。这给广大的老师和学生带来诸多的不便 , 管理起来也相当困难。使用网上选课系统可以提前进行网上选课 , 并且选课以后学生还可以在查看和更改 , 随意选择各个老师的课程 , 老师管理起来也比较方便。鉴于它的重要性 ,这就迫切需要研制开发一款功能强大 , 操作简单 , 具有人性化的网上选课系统。通过
8、对学生选课管理系统工作内容和相关数据流程分析,根据选课管理系统的需要 , 设计出满足各种用户 ( 管理员 , 教师 , 学生 ) 的实体,以及他们之间的关系 , 得到数据库的模型。系别包括系别号与系别名。专业表包括专业号与专业名。学生表包括学号 ,姓名,年龄,性2网上选课系统数据库设计别 , 年纪 , 系别号 , 专业号等。教师表包括教师号 , 姓名 , 性别 , 系别号。课程表包括课程号 , 课程名 , 学分 , 学时 , 开课状态 , 已选人数 , 限选人数等。 选课结果表包括学号 , 课程号 , 成绩。授课表包括课程号 , 教师号。管理员表包括 ID, 用户名与密码。(1)数据流图:登陆
9、学生验证返回查询 ,更改选课课程信息 课程选课 学生信息管理员信息成绩查询申请课程批准课程与否判分管理员教师登陆(最高权限 )验证教师信息返回(1)数据字典:数据项:学生学号 = 学生学号, char, 10学生姓名 = 学生姓名, char, 20学生班级 = 学生班级, char, 20学生成绩 = 学生成绩, char, 20老师工号 = 老师工号, char, 10老师姓名 = 老师姓名, char, 20课程号 = 课程号, char,10 课程名 = 课程名, char, 20 教室号= 教室号, char,10 教课时间= 教课时间, char, 153网上选课系统数据库设计 数
10、据结构 :选课结果 = 选课结果,课程内容和信息,组成 老师工号,老师姓名,课程名,教课时间,教室号 教课信息 = 教课信息,教课内容和学生上课情况,组成 教课时间,教室号,课程号,学生姓名,学生学号, 学生成绩 = 学生成绩,上课表现状态,组成 学生学号,学生姓名,上课学时,课堂表现 数据流:选课结果数据流 = 选课结果数据流,查看选课的结果,老师,学生,教室号,课时,组成 选课结果 教课信息数据流 = 教课信息数据流,学生在课堂上的表现,学生,老师,组成 教课信息 学生成绩数据流 = 学生成绩数据流,学生学号,学生姓名,上课学时,课堂表现,组成 学生成绩 数据存储 :选课结果存储 = 选课
11、结果存储,选课结果数据流,教课信息数据流,组成 选课信息,教课信息 教课信息存储 = 教课信息存储,教课信息数据流,学生成绩数据流,组成 教课信息,学生成绩 学生成绩存储 = 学生成绩存储,学生成绩数据流,学生成绩数据流,组成 学生成绩 处理过程 :学生选课结果 = 学生选课结果,输入: 学生结果数据流 ,输出: 教课信息数据流 ,处理: 学生进行选课 老师处理教课信息 = 老师处理教课信息,输入: 教课信息数据流 ,输出: 学生成绩数据流 ,处理: 老师对上课信息进行查看,并给出成绩 学生成绩录入 = 学生成绩录入,输入: 学生成绩数据流 ,输出: 学生成绩数据流 ,处理: 学生查看自己的成
12、绩,老师也可浏览各个学生的成绩 4网上选课系统数据库设计3.2 概念结构设计实体有: 学生、系别、专业、课程、教师、 管理员。总体 E-R 图系/专业属于学生选择课程批准管理员教师 申请局部 E-R 图:5网上选课系统数据库设计系别号 系别名 专业号 专业名系别 专业别姓名年龄学号年级学生姓名班级 专业系别姓名 性别系别教师号教师课程名课程号 学分状态 (教师课程学时申请用 )限选人数已选人数6网上选课系统数据库设计课 程号 教师号 ID 用户名 密码授课 管理各表关系局部 E-R 图3.3 逻辑结构设计关系模式:系别:(系别号,系别名)专业:(专业号,专业名)学生:(学号,姓名 , 年龄,性
13、别 ,年级 ,班级, 系别名 ,专业名)教师:(教师号,姓名,性别 , 系别号)课程:(课程号,课程名 , 学分 , 学时 , 状态 , 已选人数 , 限选人数)选课结果:(学号,课程号,成绩)授课:(课程号,教师号)管理员:( ID ,用户名,密码)各表关系分析:1)2)过程分析 : 选课系统面向 3 个用户群体 : 学生 , 教师与管理员。首先, 学生根据自己的学号 ( 主键 ) 与姓名登陆选课系统, 进入可以选课 , 查询自己的信息(专业,所在系部等。 ) 查询选课信息(并可以退选)。教师根据自己的教师号与姓名进行登陆, 可根据自己的知识情况申请开设课程, 并设计学时学分与人数等, 有课
14、教师学期末可以给学生成绩。管理员拥有最高权限,可以查看, 更改所有教师学生信息, 并通过调查审核批准教师的开课与否。关系分析:系别 / 专业表存储的是学生信息。学生表存储学生信息,主键学号。教师表存储教师信息 , 课程表存储选课的信息, 包括开课状态 , 是否已选满( check 约束)等 , 选课结果包括学生的学号与课程号( 当学生选课后为自动触发填充型), 授课表根据教师申请状态自动填充。管理员表拥有最高权限,可更改,批准所有信息。7网上选课系统数据库设计3.4 物理结构设计 与实施共 8 个数据表:系别表、专业表、学生表、教师表、课程表、选课结果表 , 授课表 , 管理员表。系别表 De
15、part字段数据类型长度允许空值备注Pronochar20否主键 专业号ProNamevarchar50否专业名称专业表 Profess字段数据类型长度允许空值备注Pronochar20否主键 专业号ProNamevarchar50否专业名称学生表 Student字段数据类型长度允许空值备注Snochar20否学号 主键Snamevarchar50否学生姓名SsexChar2否性别Sgradevarchar20否年级SclassVarchar20否班级Depnochar20否学生系别Pronochar20否学生专业Spasswordvarchar20否学生密码教师表 Teacher字段数据类型
16、长度允许空值备注Tnochar20否教师号主键Tnamevarchar50否教师姓名TsexChar2否教师性别Depnochar20否教师所在系TpasswordVarchar20否教师密码8网上选课系统数据库设计课程表 Course字段数据类型长度允许空值备注Cnochar20否课程号Cnamevarchar50否课程名Creditfloat否学分Cstunochar20否已选人数Ccstuchar20否限选人数选课结果表 SC字段数据类型长度允许空值备注Snochar20否学号Cnochar20否课程号Scorechar20否分数授课表 TC字段数据类型长度允许空值备注Cnochar20
17、否课程号Tnochar20否教师号管理员表: admin字段数据类型长度允许空值备注IDInt否主键 编号Passwordvarchar20否密码4结束语通过对数据库的学习,学会了对数据库的构建和运用。数据库在我们的生活中已经不可或缺,我们身边的任何信息都有数据库在存储。学习了半年,学到了很多关于数据库的知识和技能。了解了数据库的重要作用,学会了怎样去运用数据库和组建数据库,对学到这些知识和能力感到充实,同时更学会了如何去学习。4.1 收获和体会通过对本课程的学习,学习到了有关数据库设计的一些基础知识,以及设9网上选课系统数据库设计计一个简单的数据库,和对他的运行维护。在管理数据库方面自己还有
18、待于去学习。在这半年中跟老师学习了数据库原理,学会了建立数据库,查询数据,整理数据,了解了嵌入式 SQL语言的重要性。由本次的设计让自己了解到对数据库系统方面的不足,也发现自己的实际运用能力的欠缺。因此提醒自己以后要多动手,实际的运用学习到的理论知识,把他们变成自己的实际能力。虽然这次的实验设计不怎么成功,但也让自己把学到的知识运用到了实践当中,相信通过这次的实际运用,也让自己对数据库有了更深的了解。4.2 总结与展望通过这次对数据库系统的设计,学会了数据库设计的六个阶段的不同作用。数据库需求分析阶段是最基础最困难的一步,需求分析做的不好就会导致整个数据库的失败。这也正告诉我们知识这块基石的重
19、要性。实践才是真正的对我们学习的检验。在设计的过程中知道了老师教授内容的重要,自己在分析需求时分析做的不好使得设计并不顺利,这也更加警示自己考虑问题应当周全,不能太片面。希望这次设计能提高自己对数据库的设计的能力。从本次的设计中,我学习到了一些知识:实践是最好的学习方法。只有自己亲自实践才能了解到自己学到了多少,自己的不足在哪里,这样才更加的有动力去吸取知识。还有就是考虑问题不能太片面。有时自己的优点长处并不能弥补自己在其他方面的不足,做事情应当从全局考虑。因此这次设计不完全成功却更能激励自己对数据库的认知,去做好对需求的分析,运用多方面的知识,一步步的提升自己的能力,增加自己的实践,以后更好的设计数据库打下基础。10
copyright@ 2008-2022 冰豆网网站版权所有
经营许可证编号:鄂ICP备2022015515号-1