摘要:
本系统实现学生选课的基本功能,包括学生退选课,查看自己的选课信息;教师查看选课学生的信息,提交成绩;管理员添加学生、管理学生、管理成绩、添加教师、管理教师和管理课程等。系统利用.Net平台技术进行开发,实现学生选课的动态管理,使得对信息的管理更加及时、高效,提高了效率。同时还对系统的开发原理、功能特点和设计方案进行了介绍。
关键词:学生选课 数据库 管理 ASP.NET
一、课程设计的目的与要求
通过软件开发的实践训练,进一步掌握软件工程的方法和技术,提高软件开发的实际能力,培养工程设计能力和综合分析、解决问题的能力。
具体如下:
1.学习和实践在分析和设计计算机应用系统所需要的知识,包括面向对象的系统分析与设计,编码和测试方面的知识;
2.熟悉自动化的软件开发工具Rational Rose 2003,并将其运用于软件开发的全过程;
3.进一步加强和提高软件工程文档的编写能力;
4.培养协作能力和团队精神。
二、设计正文
1.概述
1.1课题题目:学生选课系统
1.2系统的主要目标:
本系统目标是实现选课系统所需的各种基本功能,包括学生选课、退课功能和教师查看选修课程、提交课程成绩功能以及管理员添加学生、维护学生信息、成绩管理、添加教师、维护教师信息、维护选修课程,还有公用的修改密码等功能。
1.3 系统的开发环境及运行环境:
操作系统: Windows XP Pro SP2
建模工具: Rational Rose 2003
数据库系统:SQL Server2000
开发工具: Visual Studio 2005
Web服务器:IIS+ASP.NET 2.0平台
2.系统需求分析
学生选课系统主要满足来自三方面的需求,这三个方面分别是学生用户、教师用户和管理员用户,也即是三类用户角。
(1)学生用户是主要的需求者,主要需求功能是查询可选课程、查看自己选课情况及进行选课、退课操作等;
(2)教师用户主要需求功能是查看自己所教授的课程、课程有哪些学生选修、以及利用本系统提交学生的成绩;
(3)管理员用户的功能需求较为复杂,包括对学生信息、教师信息、课程信息进行管理。在学生信息管理子模块中,实现对学生信息的添加、修改、删除操作,还可以输入查询条件进行查询操作。在教师管理子模块中,实现对教师信息的添加、修改、删除、查询等操作。在课程管理子模块中,实现对课程信息的添加,添加时为其分配任课教师、上课时间和地点,实现对课程的修改、删除、查看某个课程的详细信息等。
本系统将管理员用户、教师用户、学生用户的身份及权限进行严格的划分,让管理员拥有最高权限,可以查看、维护系统中的所有信息,如添加学生,添加课程,修改课程信息等;让教师拥有查看自己开设的课程的信息,以及提交所开设课程成绩的权限;让学生拥有选课和退选的权限;而修改密码模块的权限每个用户都可拥有,用以修改自己的密码信息。通过进行严格的权限划分,可以更好地进行管理,也可更好地保护用户信息安全。
2.1用例图
图2-1 学生选课系统用例图
用例图说明:
(1)系统的外部角有:学生用户、教师用户和管理员。
(2)系统主要用例的文档描述:
①学生管理用例:学生用户可见的功能,包含了选课、退课和查看选课三个用例功能。
②教师管理用例:教师用户可见的功能,包含了查看学生选课和提交成绩两个用例功能。
③信息管理用例:管理员可见的功能,这个用例进一步分为三个用例:学生信息管理用例、教师信息管理用例和课程信息管理用例。
④学生信息管理用例:信息管理用例可见的功能,实现学生信息的管理功能,包含了添加学生、修改学生信息和删除学生三个用例。
⑤教师信息管理用例:信息管理用例可见的功能,实现教师信息的管理功能,包含了添加教师、修改教师信息和删除教师三个用例。
⑥课程信息管理用例:信息管理用例可见的功能,实现课程信息的管理功能,包含了添加课程、修改课程信息和删除课程三个用例。
⑦修改密码用例:所有用户都可见的功能,用于修改用户的密码信息。
(3)系统用例之间的关系:
①学生管理用例与选课、查看选课、退课三用例之间是包含关系。
②教师管理用例与查看学生选课、提交成绩两用例之间是包含关系。
③信息管理用例与学生信息管理用例、教师信息管理用例和课程信息管理用例之间是包含关系。
④学生信息管理用例与添加学生、修改学生信息和删除学生三个用例之间是包含关系。
⑤教师信息管理用例与添加教师、修改教师信息和删除教师三个用例之间是包含关系。
⑥课程信息管理用例与添加课程、修改课程信息和删除课程三个用例之间是包含关系。
(4)系统关键用例的正常事件流图和异常事件流图
表2-1 修改密码用例的正常事件流图和异常事件流图
用例名称 | 修改密码 | |
参与者 | 管理员、教师、学生 | |
描述 | 管理员、教师、学生用户进行密码修改 | |
启动 | 单击“修改密码”链接 | |
前置条件 | 用户成功登录 | |
主事件流 | ||
用户 | 系统led刹车灯 | |
1.进入用户修改密码界面,输入旧密码一次 ,新密码两次 | ||
2.系统检查密码格式是否相符 | ||
管理科学专业 | 3.系统检查旧密码是否正确 | |
4.如果正确,进行密码修改,转入密码修改成功界面 | ||
异常流 | ||
异常流 | 密码检查未通过 | |
系统 | 返回密码修改界面,提示旧密码不正确,新密码格式不符,两次不同等密码 | |
异常 | 用户旧密码错误 | |
表2-2 提交成绩用例的正常事件流图和异常事件流图
用例名称 | 提交成绩用例 | ||
参与者 | 教师用户 | ||
描述 | 提交选自己开设课程的学生的成绩 | ||
启动 | 进入提交成绩界面 | ||
前置条件 | 用户成功登录 | ||
后置条件 | 尚未提交过成绩 | ||
主事件流 | |||
用户 | 系统 | ||
1.单击提交成绩 | |||
2.系统提交成绩页面 | |||
3.填写学生成绩,单击提交成绩 | |||
5.更新学生成绩,提示提交成功 | |||
异常流 | |||
异常流 | 用户已经提交过该门课程成绩 | ||
系统 | 提示该课程成绩已提交,不能再次提交 | ||
2.2类图
图2-2 学生选课系统类图
类图说明:
(1)BaseUser类是一个系统角用户的基类,主要方法有两个:
modifyPWD() 用于修改用户的密码;
loginCheck() 用于用户登录验证。
(2)Admin类继承自BaseUser类。
(3)Student类继承自BaseUser类,主要方法有:
studentAdd() 用于添加学生;
studentDel() 用于删除学生;
studentUpdate() 用于更新学生信息;
getStudents() 用于获取学生列表。
(4)Teacher类继承自BaseUser类,主要方法有:
teacherAdd() 用于添加教师;
teacherDel() 用于删除教师;
teacherUpdate() 用于更新教师信息;
getTeachers() 用于获取教师列表。
(5)Course类是一个课程类,主要方法有:
courseAdd() 用于添加课程;
courseDel() 用于删除课程;
courseUpdate() 用于修改课程信息;
春节年夜饭必做的10道菜getCourses() 用于获取课程列表。
(6)Elect类是一个选课表类,主要方法有:
elect() 选修课程;
electDel() 退选课程;
getElectInfo() 获取选课信息;
haveSubmit() 检测是否已提交过成绩;
submitScore() 提交成绩。
2.3顺序图
(1) 管理员修改课程信息顺序图
图2-3 管理员修改课程信息顺序图
(2) 学生用户退选课的顺序图
图2-4 学生用户退选课的顺序图
(3) 教师提交成绩顺序图
图2-5 教师提交成绩顺序图
2.4协作图(可选)
(1) 学生用户选课协作图
图2-6 学生用户选课协作图
(2) 教师提交成绩协作图
图2-7 教师提交成绩协作图
3.系统总体设计
3.1 设计问题域子系统
学生选课系统是实现学生选课退课、教师提交成绩以及学校教务管理员维护信息的一个平台,整个学生选课系统有前台和后台两部分,共分为4个模块:管理员模块,教师模块,学生模块和公有模块,分别用于完成各自的功能。以下为学生选课系统总体设计图和各功能模块说明:
(1)总体设计图
(2)各模块功能
表3-1 学生选课系统功能模块表
功能模块 | 包含子功能模块 | 功能 |
管理员模块 | 学生管理子模块 | 对学生信息的添加、修改,删除操作 |
教师管理子模块 | 对教师的添加,修改,删除,查询操作 | |
课程管理子模块 | 对课程的添加,添加时为其分配任课教师,上课时间和地点,实现对课程的修改,删除,查看某个课程的详细信息等 | |
教师模块 | 实现查看自己所教授的课程,课程有哪些学生选修,以及利用本系统提交学生的成绩 | |
学生模块 | 实现学生选课,查看所选课程,修改自己的选课信息 | |
公有模块 | 实现用户的身份验证,密码修改,退出系统等功能 | |
3.2 设计数据管理子系统
(1)数据库表
表3-2 数据库表
序号 | 数据库表 | 数据表存储的内容 |
1 | Student | 存储学生的信息 |
2 | Teacher | 存储教师的信息 |
3 | Users | 存储管理员的信息 |
4 | Elect | 存储选课的信息 |
5 | Cource | 存储课程的信息 |
6 | Depart | 存储学校系院信息 |
红包8字幽默短留言 |
(2)数据表之间的关系
图3-2 数据表之间的关系图
(3)数据库表结构
①学生表Student的详细数据字段:
表3-3 Student学生用户表
怎么发消息给所有人序号 | 字段名 | 字段类型 | 说明 | 备注 |
1 | stuID | nvarchar(20)not null | 学生学号 | 关键字 |
2 | stuPwd | nvarchar(20)not nul | 学生密码 | |
3 | stuName | nvarchar(20)not nul | 学生姓名 | |
4 | stuDepart | Int | 学生系院号 | |
5 | stuGrade | int | 学生年级 | |
6 | stuClass | int | 学生班级 | |
②教师表Teacher的详细数据字段:
表3-4 Teacher教师用户表
序号 | 字段名 | 字段类型 | 说明 | 备注 |
1 | teaID | nvarchar(20)not null | 教师编号 | 关键字 |
2 | teaPwd | nvarchar(20)not null | 教师密码 | |
3 | teaName | nvarchar(100)not null | 教师姓名 | |
4 | teaDepart | Int(4) | 教师系院号 | |
③课程表Course的详细数据字段:
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论