
学生成绩管理系统数据库设计.doc
16页学生成绩管理系统设计 JIANGXI AGRICULTURAL UNIVERSITY数据库课程设计报告题目: 学生成绩管理系统数据库设计 学 院: 姓 名: 学 号: 专 业: 班 级: 指导教师: 二0一二 年 6 月目录一、需求分析 31.1 需求概述 31.2 功能简介 3二、数据库设计 32.1 确定联系集及E-R图 32.2 画出E-R图 42.3学生成绩管理系统总E-R图 5三、逻辑数据库设计阶段 63.1 班级信息表(Class) 73.2 学生信息表(Student) 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 数据库的安全性 145.6 数据库的完整性 155.6.1 实体完整性定义 155.6.2 参照完整性定义 15六、模式求精 15七、总结 16一、需求分析1.1 需求概述针对江西农大的成绩管理工作量大、繁杂,人工处理非常困难。
学生成绩管理系统借助于计算机强大的处理能力,大大减轻了管理人员的工作量,并提高了处理的准确性学生成绩管理系统的开发运用,实现了学生成绩管理的自动化,不仅把广大教师从繁重的成绩管理工作中解脱出来、把学校从传统的成绩管理模式中解放出来,而且对学生成绩的判断和整理更合理、更公正,同时也给教师提供了一个准确、清晰、轻松的成绩管理环境1.2 功能简介能够进行数据库的数据定义、数据操纵、数据控制等处理功能,进行联机处理的相应时间要短具体功能应包括:系统应该提供课程安排数据的插入、删除、更新、查询;成绩的添加、修改、删除、查询,学生及教职工基本信息查询的功能 二、数据库设计 2.1 确定联系集及E-R图根据前面对系统进行的分析,已经初步了解了学生成绩管理系统的数据处理流程,找出与系统有关的各个实体及其相互联系如下:①、标示实体集:班级,课程,学生,成绩四个关系②、标示联系集:学生和班级:一个班由多个学生组成,一个学生只能归属于某个班; 存在“归属”的关系:N:1学生和课程:一个学生可以选修多门课程,一门课程提供给多个学生选修; 存在“选修”的关系:N:M关系Score的主码是{studentNo,courseNo,term}显然同一个学生在同一个学期不允许修读同一门课程多次关系Course的priorCourse属性参照本关系的主码courseNo属性。
这里假设一门课程最多只需要定义一门先修课程③、标示属性集:班级(班级编号,班级名称,所属学院,年级,班级人数)课程(课程号,课程名,学分,课时数,先修课程)学生(学号,姓名,性别,出生日期,籍贯,所属班级)成绩(学号,课程号,开课学期,成绩)2.2 画出E-R图班级信息图如下:ClassclasstudentNoclassNameInstituteclassNumgrade图2-2-1班级实体集的E-R图学生信息图如下:StudentstudentNostudentNamesexclasstudentNonativebirthday图2-2-2学生实体集E-R图课程信息图如下:CoursecourseNocourseNamecreditHourpriorCoursecourseHour图2-2-3课程实体集E-R图成绩信息图如下: ScorestudentNocourseNoscoreterm图2-2-4成绩实体集E-R2.3学生成绩管理系统总E-R图根据上面对实体联系的分析,可以画出E-R图如下:课程课程号课程名学时数学分先修课程选修归属学生成绩班级学号姓名性别班级人数数数年级所属学院班级名称班级编号成绩开课学期课程号学号出生日期籍贯N1NM1图2-2-5学生成绩管理系统总E-R图三、逻辑数据库设计阶段逻辑结构是独立于任何一种数据模型的信息结构。
逻辑结构的任务是把概念结构设计阶段设计好的基本E-R图转化为宜选用的DBMS所支持的数据模型相符合的逻辑结构,并对其进行优化E-R图向关系模型转化要解决的问题是如何将实体型和实体间的联系转化为关系模式,如何确定这些关系模式的属性和码设计学生成绩管理数据库,包括课程、学生、教师、成绩四个关系, 其关系模式中对每个实体定义的属性如下:课程信息表Class:(班级编号,班级名称,所属学院,年级,班级人数)学生信息表Student: (学号,姓名,性别,出生日期,籍贯,所属班级)课程信息表Course: (课程号,课程名,学分,课时数,先修课程)成绩表Score:(学号,课程号,开课学期,成绩)设计出E-R图后,可将E-R图转换为数据库模式本系统建立的数据库为“ScoreDB”,运行本系统时在库中所建立的表分别介绍如下:3.1 班级信息表(Class)字段名描述数据类型字段限制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 native民族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学号char(10)PrimarykeycourseNo课程号char(10)Primarykeyterm开课学期char(10)Not nullscore成绩numericNot null四、建表4.1 创建数据库打开SQL工具“查询分析器”在查询窗口中键入下列SQL语句create database ScoreDB执行上述SQL语句即可新建一名为ScoreDB的数据库。
4.2 创建数据表 一个完整的数据库不可缺少的就是数据表,若干个数据表的集合成一个数据库数据表主要用来存放一定格式的记录,数据表中的行被称为记录,列被称为字段创建数据表的过程其实就是定义字段的过程在此学生成绩管理系统中需要创建四个表,即班级信息表、学生信息表、课程信息表和成绩表创建数据库后,为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 tinyint, 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, / /所属班级 。
