数据库设计(学生选课系统)(18页).doc
《数据库设计(学生选课系统)(18页).doc》由会员分享,可在线阅读,更多相关《数据库设计(学生选课系统)(18页).doc(18页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、-数据库原理与应用实验指导与报告 2010 / 2011 学年 第 2 学期姓 名: 季亚 学 号: 090709118 班 级: 09数媒(1)班 指导教师: 周蓓 计算机科学与工程学院2011-第 16 页-目录实验八 数据库设计1一、概要设计11.1目的和意义11.2内容和要求1二、需求分析22.1背景22.2概要分析22.3开发技术22.4系统主要功能3三、E-R图43.1 概念设计43.2 E-R图4四、逻辑结构64.1逻辑转换64.2细化表结构6五、数据库实施85.1创建表95.2创建必要视图105.3创建必要触发器115.4创建必要存储过程13六、总结14参考文献16实验八 数据
2、库设计一、 概要设计1.1 目的和意义随着无纸化办公的普遍实现,信息的自动处理以及网络式的信息交互方式已经被人们广泛应用。让计算机来管理学生的信息是现在各个高校都在积极进行的工作之一,也是高校教学管理工作的重要内容之一。网上选课与传统的选课方式相比更加节约资源,增加了学生选课自主权。 学生选课系统作为一种现代化的教学技术,越来越受到人们的重视,是一个学校不可或缺的部分, 学生选课系统就是为了管理好选课信息而设计的。学生选课系统的将使选课管理工作规范化、系统化、程序化,避免选课管理的随意性,提高信息处理的速度和准确性,能够准确、及时、有效的查询和修改学生选课情况。与传统的选课方式相比,网上选课系
3、统利用局域网为学生选课带来了极大的便捷。学生在公共机房,或者宿舍的个人电脑上便可以通过校园网络来选课。在选课期间内,学生能够使用选课系统灵活的修改自己的选课情况,大大提高了学校选课工作的效率。教务处的教师则可以通过选课系统的管理员子系统来管理学生的选课情况,使得学生选课工作达到系统化和自动化,大大提高了学校的工作效率,为广大师生及相关人员节省了极多的时间。数据库对于一个应用系统的意义是相当重要的,一个设计良好的数据库系统一方面,能够给开发者带来便捷,更轻松的进行系统设计与编码;另一方面,对于系统的后期维护也非常重要,一个良好的数据库系统能够保证系统的可扩充性,以及系统的移植性等问题。1.2 内
4、容和要求本实验将设计出一个高校网上选课数据库系统,其要求简要如下:(1) 系统用户由三类组成:教师、学生和管理员。(2) 管理员负责的主要功能: 用户管理(老师、学生及管理员的增、删、改); 课程管理(添加、删除和修改); 选课管理(实现选课功能开放和禁止、老师成绩输入开放和禁止)。(3) 学生通过登录,可以查询课程的基本信息、实现选课、退课和成绩查询;(4) 老师通过登录,可以查看选课学生的基本信息,可以输入成绩。二、 需求分析2.1 背景全校性选修课开设的目的在于扩大学生的知识面、加强学生素质教育、培养复合型高级人才,具有不可替代的重要性。随着教育改革的不断深入和素质教育的加强,学分制的实
5、施,选修课在一个学生的培养计划中占的比重将越来越大。网上选课系统的出现使同学们能够更加自主、便捷、准确的进行选课。但是,由于一般高校中的学生都比较多,因此带来了诸多如信息管理等问题,鉴于需要将学生信息、选课信息等信息数字化以便于管理维护,我们便想到了利用数据库能够比较良好地解决此类问题,由此下面我将设计出一个高校选课系统以供参考。2.2 概要分析根据1.2节中所描述的系统分析要求,我们的高校选课系统将包含学生、教师、管理员等实体,学生可以在规定的时间内选课、退选和成绩查询等操作;教师可以查看学生的相关信息,录入学生成绩等操作;管理员可以添加管理员,管理教师、学生等信息。2.3 开发技术开发工具
6、:Microsoft SQL Server 2000 开发语言:SQL开发技术:数据库开发技术面向对象:需求者SQL Server 2000 是Microsoft 公司推出的SQL Server 数据库管理系统,该版本继承了SQL Server 7.0 版本的优点,同时又比它增加了许多更先进的功能。具有使用方便可伸缩性好与相关软件集成程度高等优点,可跨越从运行Microsoft Windows 98 的膝上型电脑到运行Microsoft Windows 2000 的大型多处理器的服务器等多种平台使用。本实验中最终将使用Microsoft SQL Server 2000数据库管理系统将我们设计的
7、数据库实现。2.4 系统主要功能实验选课系统分为教师,学生及系统管理员三类用户,学生的功能包括选课、退选、查询选课信息等,教师的功能包括学生成绩录入,查询实验信息等。管理员的功能包括新建教师、学生账户,添加课程信息,其系统功能模块如图2-1:图2-1 系统功能模块三、 E-R图本章节主要包含概念设计、E-R图,以及如何将E-R图转换为实际的物理模型等内容。3.1 概念设计在我们的数据库系统中共有6个实体:学生、教师、管理员、专业、院系、课程。(1) 学生的属性:学号、姓名、性别、生日、密码(2) 教师的属性:工号、姓名、性别、生日、密码、职称(3) 管理员的属性:工号、姓名、性别、生日、密码、
8、权限标志(4) 专业的属性:专业号码、专业名、辅导员、联系方式、专业介绍(5) 院系的属性:系号码、系名称、系主任、联系方式、系介绍(6) 课程的属性:课程号码、学时、学分、课程介绍(7) 控制设置属性:选课控制、成绩录入控制3.2 E-R图各个实体的E-R图如下所示:图1 学生图2 教师图3 管理员图4 专业图5 系图6 课程然后,将以上实体之间联系表示出来,画出数据库系统的E-R图,如图7所示:图7 数据库系统E-R图四、 逻辑结构4.1 逻辑转换根据3.2节中的E-R图可以将系统中的概念模型转换为具体的表(即关系)结构,共分为7个关系,详细信息如下所示:学生(学号、专业号码、姓名、性别、
9、生日、密码)教师(教师工号、系号码、姓名、性别、生日、密码、职称)管理员(管理员工号、姓名、性别、生日、密码、权限标志)专业(专业号码、系号码、专业名、辅导员、联系方式、专业介绍)院系(系号码、系名称、系主任、联系方式、系介绍)课程(课程号码、学时、学分、课程介绍)选课信息(学号、课程号码、教师工号、成绩)4.2 细化表结构为方便,根据上述文字描述,用英文简写为表和列取名,确定列的数据类型及必要的约束规则,给出如下所示数据库表的基本结构及说明:(1) 学生信息表列名说明数据类型约束StudentNum学号char(10)主码MajorNum专业号码char(10)not null,引用tb_m
10、ajor的外码StudentName姓名varchar(10)Not nullStudentSex性别char(2)not null,取“男”或“女”StudentBirthday生日datetimenot nullStudentPassword密码varchar(20)not null,(2) 教师信息表列名说明数据类型约束TeacherNum教师工号char(10)主码DeptNum院系号码char(10)not null,引用tb_dept的外码TeacherName姓名varchar(10)not nullTeacherSex性别char(2)not null,取“男”或“女”Teac
11、herBirthday生日datetimenot nullTeacherTitle职称varchar(20)(3) 管理员信息表列名说明数据类型约束ManagerNum管理员工号char(10)主码ManagerName姓名varchar(10)not nullManagerSex性别char(2)not null,取“男”或“女”ManagerBirthday生日datetimenot null(4) 专业信息表列名说明数据类型约束MajorNum专业号码char(10)主码DeptNum系号码char(10)not null,引用tb_dept的外码MajorName专业名varchar(
12、20)not nulMajorAssistant辅导员varchar(10)not nullMajorTel联系方式varchar(15)not null(5) 院系信息表列名说明数据类型约束DeptNum系号码char(10)主码DeptName系名称varchar(20)not nullDeptChairman系主任varchar(10)not nullDeptTel联系方式varchar(15)not nullDeptDesc系介绍textnot null(6) 课程信息表列名说明数据类型约束CourseNum课程号码char(10)主码CourseName课程名varchar(20)n
13、ot nullCourseCredit学分floatnot nullCourseClass学时smallintnot nullCourseDesc课程介绍textnot null(7) 选课信息表列名说明数据类型约束StuCourseID选课编号int主码,自动递增StudentNum学号char(10)not null,引用tb_student的外码CourseNum课程号码char(10)not null,引用tb_course的外码TeacherNum教师工号char(10)not null,引用tb_student的外码Grade成绩smallint(8) 控制设置表列名说明数据类型约
14、束IfTakeCourse选课控制char(1)not null,取“0”或“1”IfInputGrade成绩录入控制char(1)not null,取“0”或“1”备注:选课和成绩录入功能的开放和禁止,0为禁止,1为开放。五、 数据库实施本章节主要包含创建表、添加数据和创建必要的视图、触发器和存储过程等内容。5.1 创建表考虑到各个表之间的约束条件以及外键索引等要求,在创建表的时候应当按照一定的次序进行创建,否则会出现错误,还有一种方法是先创建各个基本表,然后在对特定的表添加列和外码约束,在本报告册中将采取第一种方法。(1) tb_dept院系信息表CREATE TABLE tb_dept(
15、DeptNum char(10) NOT NULL PRIMARY KEY,DeptName varchar(20) NOT NULL,DeptChairman varchar(10) NOT NULL,DeptTel varchar(15) NOT NULL,DeptDesc text NOT NULL,)(2) tb_major专业信息表CREATE TABLE tb_major(MajorNum char(10) NOT NULL PRIMARY KEY,DeptNum char(10) NOT NULL,MajorName varchar(20) NOT NULL,MajorAssis
16、tant varchar(10) NOT NULL,MajorTel varchar(15) NOT NULL,FOREIGN KEY (DeptNum) REFERENCES tb_dept(DeptNum)(3) tb_student学生信息表CREATE TABLE tb_student(StudentNum char(10) NOT NULL PRIMARY KEY,MajorNum char(10) NOT NULL,StudentName varchar(10) NULL,StudentSex char(2) NOT NULL,StudentBirthday datetime NO
17、T NULL,StudentPassword varchar(20) NOT NULL,FOREIGN KEY (MajorNum) REFERENCES tb_major(MajorNum)(4) tb_teacher教师信息表CREATE TABLE tb_teacher(TeacherNum char(10) NOT NULL PRIMARY KEY,DeptNum char(10) NOT NULL,TeacherName varchar(10) NOT NULL,TeacherSex char(2) NOT NULL,TeacherBirthday datetime NOT NULL
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 数据库 设计 学生 选课 系统 18
限制150内