![](/uploads/image/0682.jpg)
一.概述
1.1 开发背景
现如今学校招生越来越多,必然就会有大量的学生信息需要处理。如果只靠人力来完成,这将会变成一项非常繁琐、复杂的工作,而且还会出现很多意想不到的错误,给管理这些数据带来了很大的不便,也越来越不适合学校发展的需要. 教务管理系统是一个庞大而复杂的系统,它包括对院系资料的管理,对课程资料的管理,对的管理和对学生成绩的管理等等主要的功能。教务管理系统是每个学校的一项必不可少的内容,它的好坏直接影响到学校里的主要工作,一旦此系统瘫痪,学校将会受到非常严重的损失,也会影响到每一个学生.所以现如今设计一个功能完整、操作简单以及界面友好的教务管理系统变得非常重要。
为了提高教务管理工作的效率,减少错误的出现,节约大量的人力资源,现在的学校的教务管理也逐步从手工转到计算机自动化信息处理阶段。通过这个系统,用户可以方便的对院 系资料、课程资料、和学生成绩资料进行添加、修改和删除操作,还可以对和成绩进行查询操作.除此之外,对用户的添加和删除操作也很方便。
1。2 开发环境简介
系统平台:Windows xp
数据库服务器:Microsoft SQL Server
二.需求分析
2。1 功能需求
这次开发的教务管理系统大大提高了学校管理工作的效率,使用户能够方便的对院系信息、课程信息、学生信息以及成绩信息进行管理.本系统对具有不同权限的用户所开放的功能是不同的,最高级用户的权限是“管理员”,它能使用系统的所有功能,另一种用户的权限是“用户”,它只能使用系统的部分功能。
不同权限的用户能使用的功能如下:
用户管理:此项功能只能由管理员使用
修改密码:管理员和用户都能使用
信息管理:包含了系别管理、学生管理、课程管理、成绩管理四个模块,只能由 管理员使用,用户不能使用。
查询:只能由管理员使用,用户不能使用
学生成绩查询:管理员和用户都能使用
2.2 模块划分
本系统并不复杂,模块划分也比较清楚.通过对不同的功能进行分析,就可以得到系统的模块划分。
(1)登录管理模块:为了保证系统的安全性,可以根据不同的用户权限来提供不同的服务。分为管理员登录和用户登录两个子模块.
(2)系统管理模块:分为用户管理和修改密码两个子模块。其中用户管理子模块又包含了添加用户和删除用户两部分.
(3)信息管理模块:对各基本表进行管理。分为系别管理、学生管理、课程管理和成绩管理四个子模块。每一个模块又包含添加、修改和删除三个部分。
(4)信息查询模块:在各基本表的基础上进行信息查询.分为查询和学生成绩查询两个子模块.
(5)帮助模块:分为关于系统和关于作者两个子模块。
与之对应的模块划分(图一)如下所示:
图一:模块划分图
2。3 系统的窗体命名约定如表一所示:
表一:各窗体的命名约定
窗体 | 窗体名称 | 窗体实现的功能 |
LoginForm1 | 登录窗口 | 作为用户登录系统的窗口 |
FrmMain | 教务管理系统 | 系统的主界面,列出所有的功能 |
FrmUser | 用户管理 | 对用户的信息进行管理 |
FrmPasswordCharge | 修改密码 | 用户可以在此修改密码 |
FrmDepartment | 系别管理 | 对院系的信息进行管理 |
FrmCourse | 课程管理 | 对课程的信息进行管理 |
FrmStudent | 学籍管理 | 河南嵩山少林寺介绍对学生的基本信息进行管理 |
FrmGrade | 成绩管理 | 对学生的成绩进行管理 |
FrmStuQuery | 查询 | 对学生的基本信息进行查询 |
FrmGradeQuery | 学生成绩查询 | 对学生的学习成绩进行查询 |
FrmAboutSysterm | 关于系统 | 简单介绍了此系统的主要功能 |
FrmAboutAuthor | 关于作者 | 给出了作者的主要信息 |
| | |
湖南湘西旅游攻略
三.设计内容
3。1 数据库设计
由用户的需求分析和概念结构设计,最终设计了名为教务管理数据库的数据库,数据库中的表如下所示:
表1:登录信息表
记录号 | 字段名称 | 数据类型 | 字段大小 | 属性(是否可为空) |
1 | 用户名 | text | 16 | 否 |
2 | 密码 | text | 16 | 否 |
3 | 权限 | text | 16 | 否 |
| | | | |
表2:系别信息表
记录号 | 字段名称 | 数据类型 | 字段大小 | 属性(是否可为空) |
1 | 系编号 | int | 4 | 主键 |
2 | 系名 | nvarchar | 50 | 是 |
3 | 系主任 | nvarchar | 50 | 是 |
| | | | |
表3:学生信息表
记录号 | 字段名称 | 数据类型 | 字段大小 | 属性(是否可为空) |
1 | 学生编号 | char | 10 | 主键 |
2 | 学生姓名 | nvarchar | 50 | 是 |
3 | 学生性别 | char | 10 | 是 |
4 | 年龄 | int | 4 | 是 |
5 | 身份证号 | nvarchar | 50 | 是 |
6 | 所在系 | nvarchar | 50 | 是 |
| | | | |
保德天气预报表4:课程信息表
记录号 | 字段名称 | 数据类型 | 字段大小 | 属性(是否可为空) |
1 | 课程编号 | Int | 4 | 主键 |
2 | 课程名 | nvarchar | 50 | 否 |
3 | 任课老师 | nvarchar | 50 | 是 |
4 | 课程学分 | float | 8 | 是 |
5 | 开课院系 | nvarchar | 50 | 是 |
6 | 课程简介 | nvarchar | 16 | 是 |
| | | | |
表5:成绩信息表
记录号 | 字段名称 | 数据类型 | 字段大小 | 属性(是否可为空) |
1 | 学生编号 | char 三清山攻略一日游 | 10 | 主键 |
2 | 课程编号 | Int | 4 | 主键 |
3 | 平时成绩 | char | 8 | 是 |
4 | 考试成绩 | char | 8 | 是 |
| | | | |
3。2 系统中主要功能实现
(1)登录界面的设计
本系统的登录界面上主要有用户名、密码和用户权限三部分内容。用户若想进入系统,就必须给出正确的用户名和密码,而且要选择正确的用户权限.如果用户输入的用户名不存在或者密码与用户名不一致或者与用户权限不一致,都会给出相应的提示信息,告诉用户出现的错误输入.而且,如果用户进行错误的输入超过三次时,系统会自动退出.
实现这一功能的说明如下:
函数开始:
建立连接,利用Fill()函数在Systerm.Data。DataSet的指定范围中添加或刷新行,以与使用Systerm.Data。DataSet名称中的数据源中的行相匹配。
OleDbDataAdapter1。Fill(dt)
利用For循环,判断循环次数是否小于所有记录的个数
For i = 0 To dt。Rows.Count - 1
If (用户名、密码和用户权限三者匹配时 ) Then
福冈大学 Me.Hide()
Me。Finalize()
Me.AddOwnedForm(myform)
显示主窗体
If ( 用户权限 = 用户 ) Then
隐藏主窗体中的部分功能
myform。系统用户管理ToolStripMenuItem。Enabled = False
myform.教务信息管理ToolStripMenuItem.Enabled = False
myform。查询ToolStripMenuItem。Enabled = False
Else
什么也不做
End If
退出For循环
End If
Next
If ( i 〉= dt.Rows.Count 即在所有记录中都没有到与用户输入的值相同的) Then
说明在所有记录中都没有到与之匹配的用户名、密码和用户权限 Then
弹出MsgBox,警告用户出现错误
香港南丫岛MsgBox(”用户名与密码与用户权限不匹配!请验证后重新输!”, MsgBoxStyle。Exclamation, ”警告”)
将密码对应的文本框中的内容置空
End If
If ( 重复输入的次数超过3次) Then
弹出弹出MsgBox,警告用户出现错误
MsgBox(”你输入的次数已经超过了3次!系统将退出!”, MsgBoxStyle。Exclamation, ”警告")
退出
End If
函数结束
(2)信息管理模块的设计:
信息管理模块的三种操作,主要是添加记录,修该记录,删除记录三大功能.而且在执行各项功能时都会给出足够的提示信息,例如进入时的提示信息,有些信息不能为空的提示,以及操作成功的提示信息。
(a)下面以系别管理模块中添加院系来说明如何添加记录的,说明如下:
函数开始:
添加记录时给出提示信息,等待用户确认
S = MsgBox(”您确定要增加记录吗?”, 36, "提示”)
If (S <〉 6 即用户选择的是取消按钮) Then
退出函数
End If
If (系名对应的文本框为空) Then
MsgBox(”系名不能为空!”)
退出函数
End If
If (系主任对应的文本框为空) Then
。。。。.。。..。..。..。