一、需求描述与分析
1.功能性需求
用户类型有教务管理员、学生和教师。
⑴管理员后台模块
主要用于系统的数据管理,包括学生管理、教师管理、班级管理和课程管理。具体功能
①学生信息管理
②教师信息管理
③课程信息管理
④班级信息管理
⑵学生使用模块
包含三个功能
①查询功能
②浏览所选课程
③查询成绩
⑶教师使用模块
主要有两个功能
①我的课程
②登分
2.非功能性需求
采用B/S结构。还需要质量要求
data:image/s3,"s3://crabby-images/3e63d/3e63d6d3fe4004758586d17c43684f8e5ed393ad" alt=""
二、系统设计
通过自顶向下的设计方法,将在线选课系统设计成模块结构图。
1.功能模块设计
data:image/s3,"s3://crabby-images/12c21/12c2128c4b22fe99afc960546a6b126e20dc9431" alt=""
①登录验证模块
②管理员后台模块
有学生信息管理、教师信息管理、课程信息管理、班级信息管理。
data:image/s3,"s3://crabby-images/c3a4d/c3a4dbcff2f866d2a0cc438f6d812c9b05db1296" alt=""
③学生使用模块
data:image/s3,"s3://crabby-images/76ee6/76ee6a507c34365df974063a912f362cf04c1e52" alt=""
④教师使用模块
data:image/s3,"s3://crabby-images/79633/796335b6b393d076fa22a9241e6bdecd1ccbd01d" alt=""
2.数据库设计
①确定实体
根据前期的设计,确定实体有:学生、教师、课程、院系、班级和系统管理员。所包含的属性信息设计如下:
i)学生实体用于描述学生的基本信息,包括学号、姓名、性别、密码等信息。
ii)教师实体用于描述教师的基本信息,包括教师工号、姓名、性别、年龄、职称、密码等信息。
iii)课程实体用于描述课程的基本信息,包括课程号、课程名、学分、时间、地点、类别、开课学院、限选人数等信息。
iv)院系实体用于描述院系的基本信息,包括院系名称、办公地点、教师人数等信息。
v)系统管理员实体用于描述系统管理员的基本信息,包括姓名、ID 号、密码等信息
需要注意的是:在数据库设计时,实体的描述信息可根据实际需求进行增加或删减,如果实体的属性较多,在构建 E-R模型时不一定需要把所有的属性都标识在E-R模型上,可以另外用文字说明,这样也使得 E-R 模型简明清晰,便于分析。
②局部信息结构
i ) 学生-课程E-R图(多对多M-N)
data:image/s3,"s3://crabby-images/78226/78226fcfc5bc3036a420779ba0d6cf503bf2407e" alt=""
ii) 教师-课程E-R图(1:N)
data:image/s3,"s3://crabby-images/976c4/976c425b657af67171e348b725172ecb96e0bbae" alt=""
iii) 教师-院系E-R图(1:N)
data:image/s3,"s3://crabby-images/4e40c/4e40c67c9ea101641c4508c8a90aedc99ed7c70c" alt=""
iv) 学生-院系E-R图(1:N)
data:image/s3,"s3://crabby-images/7b7bd/7b7bde527ec9cc4ad2e6257b6c08391f1b1ddf0f" alt=""
v) 系统管理员-学生E-R图(多对多M-N)
data:image/s3,"s3://crabby-images/7598f/7598f714bbe28395598398d001b5ab498614b88c" alt=""
vi) 系统管理员-教师E-R图(多对多M-N)
data:image/s3,"s3://crabby-images/46d9b/46d9b428a5f6be0c19d3e98939bc76547412a07a" alt=""
vii) 系统管理员-课程E-R图(多对多M-N)
data:image/s3,"s3://crabby-images/2ab2c/2ab2c64d6658eb45f6b49307d935ebf840996d6c" alt=""
viii) 系统管理员-院系E-R图(多对多M-N)
data:image/s3,"s3://crabby-images/39e05/39e05e4903e94e23efc2a9367be370026778ec75" alt=""
③全局信息结构
i) 首先将学生-课程E-R图、教师-课程E-R图、教师-院系E-R图、学生-院系E-R图合并成为一个较大的局部信息结构。
data:image/s3,"s3://crabby-images/f40fc/f40fc7439d10b7d87ba6efa58da48d436bd06630" alt=""
ii) 再将系统管理员-学生E-R图、系统管理员-教师E-R图、系统管理员-课程E-R图、系统管理员-院系E-R图合并成为一个较大的局部信息结构。
data:image/s3,"s3://crabby-images/923ec/923ec2bc3775f6624a9d14c917b4e410eef9428d" alt=""
iii) 最后,将两个合并成为一个全局E-R
data:image/s3,"s3://crabby-images/120ca/120cafcd6caa6039d6d7510ca1a561e3df54b3c0" alt=""
④逻辑结构与规范化设计
将E-R图转换为关系模式,
学生(学号(主码)、姓名、性别、登录密码、院系编号)
院系(院系编号(主码)、系名、学生人数、教师人数、办公地点)
教师(职工号(主码)、姓名、性别、年龄、职称、登录密码、院系编号)
课程(课程号(主码)、课程名称、课程类别、学分、上课时间、上课地点、开课学院、限选人数、职工号)
系统管理员(ID 号(主码)、姓名、登录密码)
选修(学号(主码)、课程号(主码)、成绩)
管理学生(管理员 ID 号(主码)、学号(主码)、操作时间)
管理院系(管理员ID号(主码)、院系编号(主码)、操作时间)
管理教师(管理员ID号(主码)、职工号(主码)、操作时间)
管理教师(管理员ID号(主码)、课程号(主码)、操作时间)
三、系统实现
①数据库的实现
创建数据库db_xuanke;
mysql> create database db_xuanke;
Query OK, 1 row affected (0.00 sec)
根据应用数据库逻辑结构设计得出的关系模式,创建12张数据表。
data:image/s3,"s3://crabby-images/1cae9/1cae9117b7f4421fd9e25011e30f0d13f2ea1469" alt=""
data:image/s3,"s3://crabby-images/89b72/89b72f4548f4c3d1ec711bbebc8ee21a3e86ceab" alt=""
data:image/s3,"s3://crabby-images/86048/860487eac99b1cc9122c3c6412889b43f8e8482c" alt=""
mysql> use db_xuanke;
Database changed
--创建学生信息表
mysql> create table student
-> (
-> StuNo int(8) not null auto_increment,
-> StuName varchar(10) not null,
-> StuSex char(1) default 'M',
-> Pwd varchar(8) not null default '00000000',
-> DeptNo int(8) not null,
-> primary key(StuNo)
-> );
Query OK, 0 rows affected (0.01 sec)
--创建院系编码表
mysql> create table deptcode
-> (
-> DeptNo int(8) not null primary key auto_increment,
-> DeptName varchar(10) not null
-> );
Query OK, 0 rows affected (0.03 sec)
--创建院系表
mysql> create table department
-> (
-> DeptNo int(8) not null primary key auto_increment,
-> Numofstudent int(10),
-> Numofteather int(10),
-> DeptAddr varchar(10)
-> );
Query OK, 0 rows affected (0.01 sec)
--创建教师表
mysql> create table teacher
-> (
-> TeachNo int(8) not null primary key auto_increment,
-> TeachName varchar(10) not null,
-> TeachSex char(1),
-> TeachAge int(4),
-> TeachTitle varchar(6),
-> Pwd varchar(8) not null default '00000000',
-> DeptNo int(8) not null
-> );
Query OK, 0 rows affected (0.04 sec)
--创建课程编码表
mysql> create table coursecode
-> (
-> CourseNo int(8) not null primary key auto_increment,
-> CourseName varchar(10) not null
-> );
Query OK, 0 rows affected (0.01 sec)
--创建课程表
mysql> create table course
-> (
-> CourseNo int(8) not null primary key auto_increment,
-> CourseType varchar(6) not null,
-> Credit int(2) not null,
-> CourseTime date,
-> CourseAddr varchar(10),
-> DeptName varchar(10) not null,
-> Limitofnum int(4) not null,
-> TeachNo int(8) not null
-> );
Query OK, 0 rows affected (0.01 sec)
--创建系统管理员表
mysql> create table administrator
-> (
-> AdminNo int(8) not null primary key auto_increment,
-> AdminName varchar(10) not null,
-> Pwd varchar(8) not null default '00000000'
-> );
Query OK, 0 rows affected (0.01 sec)
--创建选修表
mysql> create table electing
-> (
-> StuNo int(8) not null auto_increment,
-> CourseNo int(8) not null,
-> Score int(4),
-> primary key(StuNo,CourseNo)
-> );
Query OK, 0 rows affected (0.01 sec)
--创建管理学生表
mysql> create table adminstu
-> (
-> AdminNo int(8) not null auto_increment,
-> StuNo int(8) not null,
-> OpTime date,
-> primary key(AdminNo,StuNo)
-> );
Query OK, 0 rows affected (0.01 sec)
--创建管理院系表
mysql> create table admindept
-> (
-> AdminNo int(8) not null auto_increment,
-> DeptNo int(8) not null,
-> OpTime date,
-> primary key(AdminNo,DeptNo)
-> );
Query OK, 0 rows affected (0.01 sec)
--创建管理教师表
mysql> create table adminteacher
-> (
-> AdminNo int(8) not null auto_increment,
-> TeachNo int(8) not null,
-> OpTime date,
-> primary key(AdminNo,TeachNo)
-> );
Query OK, 0 rows affected (0.06 sec)
--创建课程表
mysql> create table admincourse
-> (
-> AdminNo int(8) not null auto_increment,
-> CourseNo int(8) not null,
-> OpTime date,
-> primary key(AdminNo,CourseNo)
-> );
Query OK, 0 rows affected (0.01 sec)
②系统功能的实现
包括实现必要的数据库行为和应用软件的业务逻辑
⑴实现数据库行为
是实现数据库行为设计的结果,主要完成增、删、改、查等操作。
i) 安全控制
⑵实现应用软件的业务逻辑
四、系统测试与维护
1.登录验证功能测试
data:image/s3,"s3://crabby-images/01b26/01b2665b020df5e5dbde29628b4e03b55d52d47e" alt=""
2.管理员后台主要功能测试
⑴学生信息管理功能
data:image/s3,"s3://crabby-images/62e2e/62e2e9aacc80a9551475abaae63b5cd5de12cb7d" alt=""
⑵课程信息管理功能
data:image/s3,"s3://crabby-images/d88bf/d88bfbf80b98679e1e8aecef39014d5d88a0b9f6" alt=""
3.学生使用模块功能测试
data:image/s3,"s3://crabby-images/522c9/522c9d0eabac6d08f3d651887f6028ee033aec73" alt=""
4.教师使用模块功能测试
data:image/s3,"s3://crabby-images/91b40/91b40a20de9c247bb1861238fc16596f35a38ca6" alt=""
网友评论