ImageVerifierCode 换一换
格式:DOCX , 页数:22 ,大小:314.23KB ,
资源ID:8080851      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/8080851.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(数据库设计学生选课系统.docx)为本站会员(b****6)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

数据库设计学生选课系统.docx

1、数据库设计学生选课系统数据库系统原理课程设计报告题目名称:学生选课管理系统专业班级:计科二学位10级1班学生姓名:张晶 & 何彦忠学生学号:1102018 & 1102024指导教师:朱东芹 完成时间:2012/12/17一、概要设计1.1目的和意义随着无纸化办公的普遍实现,信息的自动处理以及网络式的信息交互方式已经被人们广泛应用。让计算机来管理学生的信息是现在各个高校都在积极进行的工作之一,也是高校教学管理工作的重要内容之一。网上选课与传统的选课方式相比更加节约资源,增加了学生选课自主权。 学生选课系统作为一种现代化的教学技术,越来越受到人们的重视,是一个学校不可或缺的部分, 学生选课系统就

2、是为了管理好选课信息而设计的。学生选课系统的将使选课管理工作规范化、系统化、程序化,避免选课管理的随意性,提高信息处理的速度和准确性,能够准确、及时、有效的查询和修改学生选课情况。与传统的选课方式相比,网上选课系统利用局域网为学生选课带来了极大的便捷。学生在公共机房,或者宿舍的个人电脑上便可以通过校园网络来选课。在选课期间内,学生能够使用选课系统灵活的修改自己的选课情况,大大提高了学校选课工作的效率。教务处的教师则可以通过选课系统的管理员子系统来管理学生的选课情况,使得学生选课工作达到系统化和自动化,大大提高了学校的工作效率,为广大师生及相关人员节省了极多的时间。数据库对于一个应用系统的意义是

3、相当重要的,一个设计良好的数据库系统一方面,能够给开发者带来便捷,更轻松的进行系统设计与编码;另一方面,对于系统的后期维护也非常重要,一个良好的数据库系统能够保证系统的可扩充性,以及系统的移植性等问题。1.2内容和要求本实验将设计出一个高校网上选课数据库系统,其要求简要如下:(1)系统用户由三类组成:教师、学生和管理员。(2)管理员负责的主要功能:1用户管理(老师、学生及管理员的增、删、改);2课程管理(添加、删除和修改);3选课管理(实现选课功能开放和禁止、老师成绩输入开放和禁止)。(3)学生通过登录,可以查询课程的基本信息、实现选课、退课和成绩查询;(4)老师通过登录,可以查看选课学生的基

4、本信息,可以输入成绩。二、需求分析2.1背景全校性选修课开设的目的在于扩大学生的知识面、加强学生素质教育、培养复合型高级人才,具有不可替代的重要性。随着教育改革的不断深入和素质教育的加强,学分制的实施,选修课在一个学生的培养计划中占的比重将越来越大。网上选课系统的出现使同学们能够更加自主、便捷、准确的进行选课。但是,由于一般高校中的学生都比较多,因此带来了诸多如信息管理等问题,鉴于需要将学生信息、选课信息等信息数字化以便于管理维护,我们便想到了利用数据库能够比较良好地解决此类问题,由此下面我将设计出一个高校选课系统以供参考。2.2概要分析我们的高校选课系统将包含学生、教师、管理员等实体,学生可

5、以在规定的时间内选课、退选和成绩查询等操作;教师可以查看学生的相关信息,录入学生成绩等操作;管理员可以添加管理员,管理教师、学生等信息。2.3开发技术开发工具:Microsoft SQL Server 2005开发语言:SQL开发技术:数据库开发技术2.4系统主要功能实验选课系统分为教师,学生及系统管理员三类用户,学生的功能包括选课、退选、查询选课信息等,教师的功能包括学生成绩录入,查询实验信息等。管理员的功能包括新建教师、学生账户,添加课程信息,其系统功能模块如图2-1:图2-1 系统功能模块三、E-R图本章节主要包含概念设计、E-R图,以及如何将E-R图转换为实际的物理模型等内容。3.1

6、概念设计在我们的数据库系统中共有6个实体:学生、教师、管理员、专业、院系、课程。(1)学生的属性:学号、姓名、性别、生日、密码(2)教师的属性:工号、姓名、性别、生日、密码、职称(3)管理员的属性:工号、姓名、性别、生日、密码、权限标志(4)专业的属性:专业号码、专业名、辅导员、联系方式、专业介绍(5)院系的属性:系号码、系名称、系主任、联系方式、系介绍(6)课程的属性:课程号码、学时、学分、课程介绍(7)控制设置属性:选课控制、成绩录入控制3.2 E-R图各个实体的E-R图如下所示:图1 学生图2 教师图3 管理员图4 专业图5 系图6 课程然后,将以上实体之间联系表示出来,画出数据库系统的

7、E-R图,如图7所示:图7 数据库系统E-R图四、逻辑结构4.1逻辑转换根据3.2节中的E-R图可以将系统中的概念模型转换为具体的表(即关系)结构,共分为7个关系,详细信息如下所示:学生(学号、专业号码、姓名、性别、生日、密码)教师(教师工号、系号码、姓名、性别、生日、密码、职称)管理员(管理员工号、姓名、性别、生日、密码、权限标志)专业(专业号码、系号码、专业名、辅导员、联系方式、专业介绍)院系(系号码、系名称、系主任、联系方式、系介绍)课程(课程号码、学时、学分、课程介绍)选课信息(学号、课程号码、教师工号、成绩)4.2细化表结构为方便,根据上述文字描述,用英文简写为表和列取名,确定列的数

8、据类型及必要的约束规则,给出如下所示数据库表的基本结构及说明:(1)学生信息表列名说明数据类型约束StudentNum学号char(10)主码MajorNum专业号码char(10)not null,引用tb_major的外码StudentName姓名varchar(10)Not nullStudentSex性别char(2)not null,取“男”或“女”StudentBirthday生日datetimenot nullStudentPassword密码varchar(20)not null,(2)教师信息表列名说明数据类型约束TeacherNum教师工号char(10)主码DeptNum

9、院系号码char(10)not null,引用tb_dept的外码TeacherName姓名varchar(10)not nullTeacherSex性别char(2)not null,取“男”或“女”TeacherBirthday生日datetimenot nullTeacherTitle职称varchar(20)(3)管理员信息表列名说明数据类型约束ManagerNum管理员工号char(10)主码ManagerName姓名varchar(10)not nullManagerSex性别char(2)not null,取“男”或“女”ManagerBirthday生日datetimenot

10、null(4)专业信息表列名说明数据类型约束MajorNum专业号码char(10)主码DeptNum系号码char(10)not null,引用tb_dept的外码MajorName专业名varchar(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

11、(15)not nullDeptDesc系介绍textnot null(6)课程信息表列名说明数据类型约束CourseNum课程号码char(10)主码CourseName课程名varchar(20)not nullCourseCredit学分floatnot nullCourseClass学时smallintnot nullCourseDesc课程介绍textnot null(7)选课信息表列名说明数据类型约束StuCourseID选课编号int主码,自动递增StudentNum学号char(10)not null,引用tb_student的外码CourseNum课程号码char(10)no

12、t null,引用tb_course的外码TeacherNum教师工号char(10)not null,引用tb_student的外码Grade成绩smallint(8)控制设置表列名说明数据类型约束IfTakeCourse选课控制char(1)not null,取“0”或“1”IfInputGrade成绩录入控制char(1)not null,取“0”或“1”备注:选课和成绩录入功能的开放和禁止,0为禁止,1为开放。表间关系关系如下图所示:五、数据库实施主要包含创建表、添加数据和创建必要的视图、触发器和存储过程等内容。实验要求为:实现选课登记,要保证学生不能选修重复的课程(实用触发器实现);

13、创建存储过程统计各学生指定学期选修课程的总学分数; 创建视图查询没有被选修的课程; 创建存储过程统计各教师任课的学生人数; 创建表间关系。5.1创建表考虑到各个表之间的约束条件以及外键索引等要求,在创建表的时候应当按照一定的次序进行创建,否则会出现错误,还有一种方法是先创建各个基本表,然后在对特定的表添加列和外码约束,在本报告册中将采取第一种方法。(1)tb_dept院系信息表CREATE TABLE tb_dept( DeptNum char(10) NOT NULL PRIMARY KEY, DeptName varchar(20) NOT NULL, DeptChairman varch

14、ar(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, MajorAssistant varchar(10) NOT NULL, MajorTel varchar(15) NOT NULL, FOREIGN KEY (DeptNum) R

15、EFERENCES 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 NOT NULL, StudentPassword varchar(20) NOT NULL, FOREIGN KEY (MajorNum) REFERE

16、NCES 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, TeacherTitle varchar(20) NULL, FOREIGN KEY (DeptNum) REFERENCES tb_

17、dept(DeptNum)(5)tb_manager管理员信息表CREATE TABLE tb_manager( ManagerNum char(10) NOT NULL PRIMARY KEY, ManagerName varchar(10) NOT NULL, ManagerSex char(2) NOT NULL, ManagerBirthdate datetime NOT NULL, ManagerRights int NOT NULL )(6)tb_course课程信息表CREATE TABLE tb_course( CourseNum varchar(10) NOT NULL PR

18、IMARY KEY, CourseName varchar(20) NOT NULL, CourseCredit float NOT NULL, CourseClass smallint NOT NULL, CourseDesc text NOT NULL,)(7)tb_stucourse学生选课信息表CREATE TABLE tb_stucourse( StudentNum char(10) NOT NULL, CourseNum char(10) NOT NULL, TeacherNum char(10) NOT NULL, Grade smallint NULL, FOREIGN KEY

19、 (StudentNum) REFERENCES tb_student(StudentNum), FOREIGN KEY (CourseNum) REFERENCES tb_Course(CourseNum), FOREIGN KEY (TeacherNum) REFERENCES tb_teacher(TeacherNum), )(8)tb_control控制设置表CREATE TABLE tb_control( IfTakeCourse char(1) NOT NULL check(IfTakeCourse in ( 0, 1), IfInputGrade char(1) NOT NULL

20、 check(IfInputGrade in ( 0, 1),)5.2创建必要视图(1)(非题目要求视图)建立学生成绩视图vi_grade,从学生、老师、选课表中选择Grade不为空的记录,其关键代码如下所示:CREATE VIEW vi_gradeASSELECT tb_stucourse.StudentNum,StudentName,CourseName ,CourseCredit,TeacherName,GradeFROM tb_stucourse,tb_student,tb_course,tb_teacherwhere tb_stucourse.StudentNum=tb_studen

21、t.StudentNum and tb_stucourse.TeacherNum=tb_teacher.TeacherNum and tb_stucourse.CourseNum=tb_course.CourseNum and Grade is not null(2)(非题目要求视图)建立专业学生信息视图vi_major,从学生、专业表中选择学生中的专业号码与专业表中专业号码相等的记录,其关键代码如下所示:CREATE VIEW vi_majorASSELECT tb_major.MajorName,StudentNum,StudentName,StudentSex,StudentBirthd

22、ayFROM tb_major,tb_studentWHERE tb_major.MajorNum=tb_student.MajorNum CREATE TRIGGER tri_takecourse ON tb_stucourseFOR INSERT,UPDATEAS IF(SELECT COUNT(*) FROM tb_stucourse,inserted WHERE tb_stucourse.CourseNum=inserted.CourseNum)40BEGIN PRINT 所对应课程选课人数不能超过40个! ROLLBACKENDELSE IF (SELECT COUNT(*) FRO

23、M tb_student,inserted WHERE tb_student.StudentNum=inserted.StudentNum)5BEGIN PRINT 对应学生的选课不能超过5门! ROLLBACKENDELSE IF (SELECT IfTakeCourse FROM tb_control)=0BEGIN PRINT 当前不是选课时间段! ROLLBACKEND (3) (题目要求视图)创建视图查询没有被选修的课程5.3创建必要触发器(1)(非题目要求触发器)建立学生添加院系触发器tri_adddept,当该表中已存在所对应院系号码的院系时,系统给与错误提示并回滚,其关键代码如

24、下所示:CREATE TRIGGER tri_adddept ON tb_deptFOR INSERT,UPDATEASIF (SELECT COUNT(*) FROM tb_dept,inserted WHERE tb_dept.DeptNum=inserted.DeptNum)0BEGIN PRINT 院系号码产生冲突,请核对后重试! ROLLBACKEND(2)(非题目要求触发器)建立学生添加专业触发器tb_major,当专业信息中的院系号不对或者该表中已存在所对应专业号码的专业时,系统给与错误提示并回滚,其关键代码如下所示:CREATE TRIGGER tri_addmajor ON

25、tb_majorFOR INSERT,UPDATEAS IF(SELECT COUNT(*) FROM tb_dept,inserted WHERE tb_dept.DeptNum=inserted.DeptNum)=0BEGIN PRINT 未找到该专业的院系信息,请添加相应院系后重试! ROLLBACKENDELSE IF (SELECT COUNT(*) FROM tb_major,inserted WHERE tb_major.MajorNum=inserted.MajorNum)0BEGIN PRINT 院系号码产生冲突,请核对后重试! ROLLBACKEND(3)(非题目要求触发器

26、)建立添加学生触发器tri_addstudent,当学生信息中的专业号不对或者系统中已存在所对应学号的学生时,系统给与错误提示并回滚,其关键代码如下所示:CREATE TRIGGER tri_addstudent ON tb_studentFOR INSERT,UPDATEAS IF(SELECT COUNT(*) FROM tb_major,inserted WHERE tb_major.MajorNum=inserted.MajorNum)=0BEGIN PRINT 未找到该学生的专业信息,请添加相应专业后重试! ROLLBACKENDELSE IF (SELECT COUNT(*) FR

27、OM tb_student,inserted WHERE tb_student.StudentNum=inserted.StudentNum)0BEGIN PRINT 学号产生冲突,请核对后重试! ROLLBACKEND(4)(非题目要求触发器)建立学生选课触发器tri_takecourse,课程选课人数超过40个或者对应学生选课门数超过5门或者当前时间不是选课时间段时,系统给与错误提示并回滚,其关键代码如下所示:CREATE TRIGGER tri_takecourse ON tb_stucourseFOR INSERT,UPDATEAS IF(SELECT COUNT(*) FROM tb

28、_stucourse,inserted WHERE tb_stucourse.CourseNum=inserted.CourseNum)40BEGIN PRINT 所对应课程选课人数不能超过40个! ROLLBACKENDELSE IF (SELECT COUNT(*) FROM tb_student,inserted WHERE tb_student.StudentNum=inserted.StudentNum)5BEGIN PRINT 对应学生的选课不能超过5门! ROLLBACK ENDELSE IF (SELECT IfTakeCourse FROM tb_control)=0BEGI

29、N PRINT 当前不是选课时间段! ROLLBACKEND(5) (题目要求的触发器)实现选课登记。要保证学生不能选修重复的课程gouse studentmanager if object_id(tri_cover,tr) is not nulldrop trigger tri_covergoCREATE TRIGGER tri_cover ON tb_stucourseFOR INSERT,UPDATEAS IF(SELECT COUNT(*) FROM tb_stucourse,inserted WHERE tb_stucourse.studentnum=inserted.studentnum)0BEGIN PRINT 不能重复选课! ROLLBACKEND5.4创建必要存储过程(1)(非题目要求存储过程)建立学生选课存储过程tri_takecourse,其作用为查询所有学生的选课记录,其关键代码如下所示:CREATE PROC proc_getcourseStudentNum c

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1