收藏 分销(赏)

学生成绩管理系统数据库设计.pdf

上传人:精*** 文档编号:1501739 上传时间:2024-04-29 格式:PDF 页数:16 大小:435.11KB
下载 相关 举报
学生成绩管理系统数据库设计.pdf_第1页
第1页 / 共16页
学生成绩管理系统数据库设计.pdf_第2页
第2页 / 共16页
学生成绩管理系统数据库设计.pdf_第3页
第3页 / 共16页
学生成绩管理系统数据库设计.pdf_第4页
第4页 / 共16页
学生成绩管理系统数据库设计.pdf_第5页
第5页 / 共16页
点击查看更多>>
资源描述

1、 JIANGXI AGRICULTURAL UNIVERSITY数据库课程设计报告数据库课程设计报告题目:学生成绩管理系统数据库设计学生成绩管理系统数据库设计 学学 院:院:姓姓 名:名:学学 号:号:专专 业:业:班班 级:级:指导教师:指导教师:二二 0 0 一二一二 年年 6 6 月月学生成绩管理系统设计2目录目录一、需求分析.31.1 需求概述.31.2 功能简介.3二、数据库设计.32.1 确定联系集及 E-R 图.32.2 画出 E-R 图.42.3 学生成绩管理系统总 E-R 图.5三、逻辑数据库设计阶段.63.1 班级信息表(Class).73.2 学生信息表(Student)

2、.73.3 课程信息表(Course).83.4 成绩表(Score).8四、建表.84.1 创建数据库.84.2 创建数据表.9五、数据库的运行和维护.105.1 定义.105.1.1 基本表的创建,建表语句.105.1.2 基本表的删除.115.2 数据操作.115.2.1 单表查询:.115.2.2 连接查询.115.2.3 操作结果集查询.125.2.4 嵌套查询.125.3 数据库更新操作.135.3.1 插入数据.135.3.2 修改数据.135.3.3 删除数据.135.4 为数据库建立索引.145.4.1 索引的建立.145.4.2 索引的删除.145.5 数据库的安全性.14

3、5.6 数据库的完整性.155.6.1 实体完整性定义.155.6.2 参照完整性定义.15六、模式求精.15七、总结.16学生成绩管理系统设计3一、需求分析一、需求分析1.1 需求概述需求概述针对江西农大的成绩管理工作量大、繁杂,人工处理非常困难。学生成绩管理系统借助于计算机强大的处理能力,大大减轻了管理人员的工作量,并提高了处理的准确性。学生成绩管理系统的开发运用,实现了学生成绩管理的自动化,不仅把广大教师从繁重的成绩管理工作中解脱出来、把学校从传统的成绩管理模式中解放出来,而且对学生成绩的判断和整理更合理、更公正,同时也给教师提供了一个准确、清晰、轻松的成绩管理环境。1.2 功能简介功能

4、简介能够进行数据库的数据定义、数据操纵、数据控制等处理功能,进行联机处理的相应时间要短。具体功能应包括:系统应该提供课程安排数据的插入、删除、更新、查询;成绩的添加、修改、删除、查询,学生及教职工基本信息查询的功能。二、数据库设计二、数据库设计2.1 确定联系集及确定联系集及 E-R 图图根据前面对系统进行的分析,已经初步了解了学生成绩管理系统的数据处理流程,找出与系统有关的各个实体及其相互联系如下:、标示实体集:班级,课程,学生,成绩四个关系。、标示联系集:学生和班级:一个班由多个学生组成,一个学生只能归属于某个班;存在“归属”的关系:N:1学生和课程:一个学生可以选修多门课程,一门课程提供

5、给多个学生选修;存在“选修”的关系:N:M学生成绩管理系统设计4关系 Score 的主码是studentNo,courseNo,term显然同一个学生在同一个学期不允许修读同一门课程多次关系 Course 的 priorCourse 属性参照本关系的主码 courseNo 属性。这里假设一门课程最多只需要定义一门先修课程。、标示属性集:班级(班级编号,班级名称,所属学院,年级,班级人数)课程(课程号,课程名,学分,课时数,先修课程)学生(学号,姓名,性别,出生日期,籍贯,所属班级)成绩(学号,课程号,开课学期,成绩)2.2 画出画出 E-R 图图班级信息图如下:Classclasstudent

6、NoclassNameInstituteclassNumgrade图 2-2-1 班级实体集的 E-R 图学生信息图如下:StudentstudentNostudentNamesexclasstudentNonativebirthday图 2-2-2 学生实体集 E-R 图学生成绩管理系统设计5课程信息图如下:CoursecourseNocourseNamecreditHourpriorCoursecourseHour图 2-2-3 课程实体集 E-R 图成绩信息图如下:ScorestudentNocourseNoscoreterm图 2-2-4 成绩实体集 E-R2.3 学生成绩管理系统总学

7、生成绩管理系统总 E-R 图图根据上面对实体联系的分析,可以画出 E-R 图如下:学生成绩管理系统设计6图 2-2-5 学生成绩管理系统总 E-R 图三、逻辑数据库设计阶段三、逻辑数据库设计阶段逻辑结构是独立于任何一种数据模型的信息结构。逻辑结构的任务是把概念结构设计阶段设计好的基本 E-R 图转化为宜选用的 DBMS 所支持的数据模型相符合的逻辑结构,并对其进行优化。E-R 图向关系模型转化要解决的问题是如何将实体型和实体间的联系转化为关系模式,如何确定这些关系模式的属性和码。课程课程号课程名学时数学分先修课程选修归属学生成绩班级学号姓名性别班级人数数数年级所属学院班级名称班级编号成绩开课学

8、期课程号学号出生日期籍贯N1NM1学生成绩管理系统设计7设计学生成绩管理数据库,包括课程、学生、教师、成绩四个关系,其关系模式中对每个实体定义的属性如下:课程信息表Class:(班级编号,班级名称,所属学院,年级,班级人数)学生信息表Student:(学号,姓名,性别,出生日期,籍贯,所属班级)课程信息表Course:(课程号,课程名,学分,课时数,先修课程)成绩表Score:(学号,课程号,开课学期,成绩)设计出 E-R 图后,可将 E-R 图转换为数据库模式。本系统建立的数据库为“ScoreDB”,运行本系统时在库中所建立的表分别介绍如下:3.1 班级信息表班级信息表(Class)字段名描

9、述数据类型字段限制classNo班级编号char(10)PrimarykeyclassName班级名称varchar(30)Not nullinstitute所属学院varchar(30)Not nullgrade年级smallintNot nullclassNum班级人数tinyintNot null3.2 学生信息表学生信息表(Student)字段名描述数据类型字段权限studentNo学号char(10)Primarykey studentName姓名Varchar(30)Not null sex性别char(2)Not nullbirthday出生日期datetimeNot null

10、学生成绩管理系统设计8native民族varchar(30)Not nullclassNo所属班级varchar(30)Not null3.3 课程信息表(课程信息表(Course)字段名属 性数据类型字段权限courseNo课程号char(10)PrimarykeycourseName课程名varchar(30)Not nullcreditHour学分numericNot nullcourseHour课时数tinyintNot nullpriorCourse先修课程varchar(30)Not null3.4 成绩表(成绩表(Score)字段名属 性数据类型字段权限studentNo学号ch

11、ar(10)PrimarykeycourseNo课程号char(10)Primarykeyterm开课学期char(10)Not nullscore成绩numericNot null四、建表四、建表4.1 创建数据库创建数据库打开 SQL 工具“查询分析器”在查询窗口中键入下列 SQL 语句create database ScoreDB执行上述 SQL 语句即可新建一名为 ScoreDB 的数据库。学生成绩管理系统设计94.2 创建数据表创建数据表 一个完整的数据库不可缺少的就是数据表,若干个数据表的集合成一个数据库。数据表主要用来存放一定格式的记录,数据表中的行被称为记录,列被称为字段。创建

12、数据表的过程其实就是定义字段的过程。在此学生成绩管理系统中需要创建四个表,即班级信息表、学生信息表、课程信息表和成绩表。创建数据库后,为 ScoreDB 数据库添加数据表,步骤如下。新建查询窗口在查询窗口中键入下列 SQL 语句create table Class(/创建班级信息表 classtudentNo char(10)primary key,/班级编号 classtudentName varchar(30)not null,/班级名称 institute varchar(30)Not null /所属学院 grade smallint,Not null /年级 classNum tin

13、yint,Not null /班级人数 )执行上述 SQL 语句即可创建课程信息表相关表格create table Student(/创建学生信息表 studentNo char(10)primary key,/学号 studentName varchar(30)not null,/姓名 sex char(2)not null,/性别 birthday datetime not null,/出生日期 native varchar(30)not null,/民族 classtudentNo Char(10)not null,/所属班级 )执行上述 SQL 语句即可创建学生信息表相关表格creat

14、e table Course(/创建教师信息表 courseNo char(10)primary key,/课程号 courseName varchar(30)not null,/课程名学生成绩管理系统设计10 creditHour numeric not null,/学分 courseHour tinyint not null,/课时数 priorCourse varchar(30)not null,/先修课程 )执行上述 SQL 语句即可创建教师信息表相关表格create table Score(/创建成绩表 studentNo char(10)primary key,/学号 course

15、No char(10)primary key,/课程号 term char(10)not null,/开课学期 score numeric not null,/成绩 )执行上述 SQL 语句即可创建成绩表相关表格五、数据库的运行和维护五、数据库的运行和维护5.1 定义定义基本表的创建、修改及删除;索引的创建和删除。5.1.1 基本表的创建,建表语句基本表的创建,建表语句 create table Student(/创建学生表 studentNo char(10)not null,studentName varchar(30)not null,sex char(2)not null,birthd

16、ay datetime not null,native varchar(20)not null,classtudentNo Char(10)not null,constraint studentPK primary key(StudentNO),学生成绩管理系统设计11 constraint studentPK1 foreign key(classtudentNo)references class(classtudentNo)5.1.2 基本表的删除基本表的删除drop table Student5.2 数据操作数据操作5.2.1 单表查询:单表查询:查询学号为“0800006”生的姓名sel

17、ect studentNamefrom Studentwhere studentNo=0800006结果:5.2.2 连接查询连接查询查询学生的学号、姓名,所选课程的课程号、课程名和成绩Select Student.studentNo,Student.studentName,Class.classNo,Class.className,Score.scorefrom Student,Class,Score,CourseWhere Student.studentNo=Score.studentNo and Student.classNo=Class.classNo and Course.cours

18、eNo=Score.courseNo结果:学生成绩管理系统设计125.2.3 操作结果集查询操作结果集查询查询 0700003 号同学和 0800002 号同学共同选修的课程Select courseNoFrom ScoreWhere studentNo=0700003IntersectSelect courseNoFrom scoreWhere studentNo=0800002查询结果:5.2.4 嵌套查询嵌套查询 查询选修了“CS0701”这门课的所有学生的学号、姓名、出生日期以及籍贯。Select studentNo,studentName,birthday,nativeFrom St

19、udentWhere studentNo in学生成绩管理系统设计13 (select studentNo From score Where classNo=CS0701)查询结果:5.3 数据库更新操作数据库更新操作5.3.1 插入数据插入数据向 Student 表中添加一项记录:姓名:叶问,学号:0800016,性别:男,出生年月:1992-6-19,籍贯:南昌,班级编号:CP0802InsertInto Student(studentNo,studentName,sex,birthday,native,classNo)Values(0800016,叶问,男,1992-6-19,南昌,CP

20、0802结果:5.3.2 修改数据修改数据修改吴敏的学号为 0800019Update StudentSet StudentNo=0800019Where StudentName=吴敏;5.3.3 删除数据删除数据删除所有金融学院学生的记录学生成绩管理系统设计14Delete from ClassWhere(institute=金融学院);5.4 为数据库建立索引为数据库建立索引5.4.1 索引的建立索引的建立create index studentNameSM on Student(studentName)5.4.2 索引的删除索引的删除drop index studentNameSM on

21、 Student(studentName)5.5 数据库的安全性数据库的安全性所谓计算机系统安全性,是指为计算机系统建立和采取的各种安全保护措施,以保护计算机系统中的硬件,软件及数据,防止其偶然或恶意的原因使系统遭到破坏,数据遭到更改或泄露等。为防止因用户非法使用数据库造成数据泄露、更改或破坏,必须采取一些安全性控制措施以保证数据库中数据的安全、可靠和正确有效。安全性控制的防范对象是非法用户和非法操作,防止他们对数据库数据的非法存取。主要采用用户标识及鉴定,使用用户名或用户标识号来标明用户身份。用户想要对对数据库内容进行相关操作,必须申请一个用户名或用户标识号,每次登陆都必须输入该用户名以及相

22、应正确的口令,然后系统对其进行验证,只有通过验证的用户方可对数据库进行操作。学生成绩管理系统设计155.6 数据库的完整性数据库的完整性5.6.1 实体完整性定义实体完整性定义:在班级表 Class 中将 classNo 定义为主码。create table Class(/创建class表 classNo char(10)not null,className varchar(30)not null,institute varchar(30)Not null,grade smallint Not null,classNum tinyint null ,constraint ClassPK pri

23、mary key(classNo)5.6.2 参照完整性定义参照完整性定义:在学生成绩表 Score 中将 studentNo、courseNo 定义为外码。create table Score(studentNo char(10)not null,courseNo char(10)not null,term char(10)not null,score numeric(5,1)default 0 not null,Check(Score between 0.0 and 100.0),Constraint ScorePK primary key(studentNo,courseNo),Cons

24、traint ScoreFK1 foreign key(studentNo)References Student(studentNo),Constraint ScoreFK2 foreign key(courseNo)References Course(courseNo)六、模式求精六、模式求精 通常,如果能仔细分析用户的需求,并正确的识别出所有的实体集和联系集,有 E-R 图生成的数据库模式往往不需要太多的进一步模式求精。然而,如果一个实体集中的属性之间存在函数依赖(不包括主码的依赖关系),则需要根据函数依赖理论将其进行规范化。学生成绩管理系统设计16 通过分析以上关系可知 Course 关

25、系模式中存在一个对非主属性的函数依赖关系:courseName-priorCourse,由此导致的问题是数据冗余,即每一个相同等级会员都需要存放 priorCourse 信息。该模式不满足 BCNF 范式。因此,需要对 Course 进行分解。依据 BCNF 可分解为一下两个模式:NewCourse1(classNo,courseName,creditHour,courseHour)NewCourse2(courseName,priorCourse)七、总结七、总结 本学生成绩查询系统主要参照课本,相对来说比较简单。但是由于主要以课本为依据,所以整个设计做下来基本掌握了课本上数据库的基础操作。设计过程中我也遇到了一些问题,再向其他同学请教的过程中我收获了很多。(1)在设计表时应注意使用正确的字段类型。(2)在建表语句中,如果这个表的主键是多个属性的组合主键,则必须作为表级完整性进行定义。随着学生成绩管理类型的不断增加和成绩管理要求的不断提高,管理方面的工作量将会越来越大,并且其工作将是一件十分烦琐和非常容易出错的事情。在这样的情况下有一个实用学生成绩管理系统是有其必然性的,如果能做出一个完善的学生成绩管理系统就使管理方面的工作量减少很多。总的来说,通过这次的数据库课程设计锻炼了我们的操作能力和让我们从实际上去分析一件事比较全面和对数据库设计有了更深的了解。

展开阅读全文
相似文档                                   自信AI助手自信AI助手
猜你喜欢                                   自信AI导航自信AI导航
搜索标签

当前位置:首页 > 通信科技 > 数据库/数据算法

移动网页_全站_页脚广告1

关于我们      便捷服务       自信AI       AI导航        获赠5币

©2010-2024 宁波自信网络信息技术有限公司  版权所有

客服电话:4008-655-100  投诉/维权电话:4009-655-100

gongan.png浙公网安备33021202000488号   

icp.png浙ICP备2021020529号-1  |  浙B2-20240490  

关注我们 :gzh.png    weibo.png    LOFTER.png 

客服