项目实训学生信息管理系统.docx
- 文档编号:26466511
- 上传时间:2023-06-19
- 格式:DOCX
- 页数:107
- 大小:1.18MB
项目实训学生信息管理系统.docx
《项目实训学生信息管理系统.docx》由会员分享,可在线阅读,更多相关《项目实训学生信息管理系统.docx(107页珍藏版)》请在冰豆网上搜索。
项目实训学生信息管理系统
项目实训
学生信息管理系统设计与实现
前言:
项目概述
学生信息管理系统介绍
项目名称
学生信息管理系统
代码量
3000行
项目简介
该系统可以帮助教辅人员进行学生基本信息的日常管理和维护;进行学生选课模拟以及重要数据备份等功能。
项目目的
①掌握WinForm图形用户界面开发技术
②掌握ADO.NET数据库访问技术
涉及的主要技术
WinForm、ADO.NET、SQLServer
数据库环境
MicrosoftSQLServer2000
编程环境
VisualStudio2005
项目特点
①基于.NET采用C#语言开发
②项目属于C/S结构程序
技术重点
①WinForm窗体主要控件的应用
②数据库各类对象的应用,例如:
存储过程、触发器等
技术难点
ADO.NET数据库访问技术
1项目需求以及分析设计
1.1项目需求分析
随着学校规模的不断扩大,每个院系的专业、班级、学生的数量急剧增加,有关学生选课的各种信息量也成倍增长,而很多高校的学生信息管理工作仍停留在复杂的人工操作上,重复工作较多,工作量大,效率低。
因此,迫切需要开发学生信息管理系统来提高管理工作的效率。
经过详细调研,我们确定了一个简易的学生信息管理系统的基本需求。
①需要进行身份认证登录
系统只允许合法用户进行登陆操作,并且该系统主要面向教学管理人员提供服务(例如教学秘书、辅导员等)。
合法用户登陆后可以进行系统的主要功能操作。
②数据查询服务
系统需要为服务对象提供两种服务:
一是进行学生基本信息的浏览;二是进行学生成绩信息查询服务。
③数据添加服务
系统根据需要可以添加学生基本信息以及添加学生的选课信息等操作。
④数据更新服务
系统根据需要可以更新学生的基本信息。
⑤数据删除服务
系统根据需要可以删除学生的基本信息,但是要求备份删除学生的所有信息。
⑥系统扩展服务
本项目限于篇幅等,在后面主要描述并实现了系统登录、学生基本信息浏览、成绩信息查询、学生基本信息的添加、更新和删除以及学生选课的功能。
有关其他实体信息的管理,例如:
成绩信息、课程信息等维护功能没有实现。
但是大家完全可以根据后面系统提供的框架来扩展系统的其他功能。
此外,根据需要,我们采用基于C/S结构来开发学生信息管理系统。
1.2项目功能描述
根据需求分析,学生信息管理系统为用户提供的功能主要分为以下几类:
系统管理服务:
系统系统登录、注销以及系统退出功能。
数据查询和统计服务:
学生基本信息浏览和查询、学生成绩信息查询等功能。
数据添加服务:
学生基本信息添加、学生选课、其他可以扩展的功能(院系信息添加、课程信息添加、成绩信息添加、管理员账户信息添加等未实现)。
数据更新服务:
学生基本信息更新、其他可以扩展的功能(院系信息更新、课程信息更新、成绩信息更新、管理员密码修改功能等未实现)。
数据删除服务:
学生基本信息删除、其他可以扩展的功能(院系信息删除、课程信息删除、成绩信息删除、管理员删除等功能未实现)。
系统介绍服务:
系统基本信息介绍、系统使用帮助(未实现)等。
根据以上系统功能描述,绘制学生信息管理系统的功能模块划分如图14.1.2-1所示。
图1.2-1:
“学生信息管理系统”功能模块图
1.3数据库设计
本系统后台数据库采用的是SQLServer2000,根据系统的功能描述以及系统的详细设计,学生成绩信息管理系统中各种数据信息之间的关系如图1.3-1所示。
图1.3-1:
“学生成绩信息管理系统”数据库关系图
下面针对图1.3-1中的数据库基本表的具体设计进行详细介绍。
表名:
admin(管理员表),如表1.3-1所示。
字段名称
数据类型
字段说明
字段属性
userName
Varchar(20)
用户名
主键
password
Varchar(20)
密码
限制最低6位,不能为空
表1.3-1:
管理员表设计说明
表名:
Dept(院系表),如表1.3-2所示。
字段名称
数据类型
字段说明
字段属性
deptID
Char(4)
院系编号
主键
deptName
Nvarchar(30)
院系名称
不许为空且唯一
phone
Varchar(12)
联系电话
表1.3-2:
院系表设计说明
表名:
stu(学生表),如表1.3-3所示。
字段名称
数据类型
字段说明
字段属性
stuID
Char(12)
学号
主键
stuName
Nvarchar(20)
姓名
不许为空
stuSex
Nchar
(1)
性别
只能输入:
男、女
stuBirth
Datetime
出生日期
要求年龄不能大于30岁
stuPolitic
Tinyint
政治面貌
只能输入1、2、3(其中1表示党员,2表示团员,3表示其他)
stuDept
Char(4)
所属院系
参照院系表院系编号取值
stuResume
Ntext
简历
stuPhoto
Image
照片
stuPcard
Char(18)
身份证编号
表1.3-3:
学生表设计说明
表名:
course(课程表),如表1.3-4所示。
字段名称
数据类型
字段说明
字段属性
courseID
Char(6)
课程编号
主键
courseName
Nvarchar(30)
课程名称
不许为空,唯一
Credit
Tinyint
学分
其值不能大于5
courseTime
Varchar(30)
上课时间
stuLimited
Tinyint
限选人数
默认值:
250
stuPreSelect
Tinyint
已选人数
默认值:
0,并且不能大于stuLimited
表1.3-4:
课程表设计说明
表名:
grade(成绩表),如表1.3-5所示。
字段名称
数据类型
字段说明
字段属性
stuID
Char(12)
学号
参照学生表学号字段取值
courseID
Char(6)
课程编号
参照课程表课程编号字段取值
grade
Decimal(5,2)
成绩
成绩必须介于0和100之间
说明:
stuID和courseID联合主键
表1.3-5:
成绩表设计说明
2项目详细设计以及功能实现
本章主要任务是从实际应用出发,使学生能够掌握SQLServer等大型数据库技术,掌握C#+SQLServer等大型数据库软件进行大型数据库桌面应用程序开发的基本过程和基本方法,并能够运用C#进行简单的办公自动化系统编程。
在进行项目详细设计之前,首先创建一个名为StuInfoManage的windows应用程序项目。
2.1数据库通用访问类的创建
考虑到整个项目中多个窗体的很多位置都需要涉及到数据库的访问操作,所以我们将数据库操作频繁使用的部分代码抽取出来,组合而成数据库访问类,从而避免重复编写相同代码的工作。
常见的数据库访问操作主要有:
更新操作(包括插入数据、修改数据和删除数据)、查询操作(指直接执行SQL语句进行数据库操作)、存储过程的执行操作(主要包括返回结果集的存储过程以及使用返回值的存储过程)等。
在StuInfoManage项目中进行以下操作:
①添加一个类:
将其中创建的Class1.cs重命名为SqlHelper.cs。
②在该类中添加如下代码:
publicclassabstractclassSqlHelper
{
//获取数据库连接字符串,其属于静态变量且只读,项目中所有文档可以直接使用,但不能修改
publicstaticreadonlystringConnectionString="server=.;database=stuInfoManage;IntegratedSecurity=true;";
///执行一个不需要返回值的SqlCommand命令,通过指定专用的连接字符串。
publicstaticintExecuteNonQuery(stringconnectionString,CommandTypecmdType,stringcmdText,paramsSqlParameter[]commandParameters)
{
SqlCommandcmd=newSqlCommand();
using(SqlConnectionconn=newSqlConnection(connectionString))
{
//通过PrePareCommand方法将参数逐个加入到SqlCommand的参数集合中
PrepareCommand(cmd,conn,null,cmdType,cmdText,commandParameters);
intval=cmd.ExecuteNonQuery();
//清空SqlCommand中的参数列表
cmd.Parameters.Clear();
returnval;
}
}
///执行一条返回SqlDataReader的SqlCommand命令,通过专用的连接字符串。
publicstaticSqlDataReaderExecuteReader(stringconnectionString,CommandTypecmdType,stringcmdText,paramsSqlParameter[]commandParameters)
{
SqlCommandcmd=newSqlCommand();
SqlConnectionconn=newSqlConnection(connectionString);
try
{
PrepareCommand(cmd,conn,null,cmdType,cmdText,commandParameters);
SqlDataReaderrdr=cmd.ExecuteReader(CommandBehavior.CloseConnection);
cmd.Parameters.Clear();
returnrdr;
}
catch
{
conn.Close();
throw;
}
///执行一条返回DataSet的SqlCommand命令,通过专用的连接字符串。
publicstaticDataSetExecuteDataset(stringconnectionString,CommandTypecommandType,stringcommandText,paramsSqlParameter[]commandParameters)
{
SqlCommandcmd=newSqlCommand();
using(SqlConnectioncn=newSqlConnection(connectionString))
{
cn.Open();
PrepareCommand(cmd,cn,(SqlTransaction)null,commandType,commandText,commandParameters);
SqlDataAdapterda=newSqlDataAdapter(cmd);
DataSetds=newDataSet();
da.Fill(ds);
cmd.Parameters.Clear();
returnds;
}
}
///为执行命令准备参数
privatestaticvoidPrepareCommand(SqlCommandcmd,SqlConnectionconn,SqlTransactiontrans,CommandTypecmdType,stringcmdText,SqlParameter[]cmdParms)
{
//判断数据库连接状态
if(conn.State!
=ConnectionState.Open)
conn.Open();
cmd.Connection=conn;
cmd.CommandText=cmdText;
//判断是否需要事物处理
if(trans!
=null)
cmd.Transaction=trans;
cmd.CommandType=cmdType;
if(cmdParms!
=null)
{
foreach(SqlParameterparmincmdParms)
cmd.Parameters.Add(parm);
}
}
/*
*功能:
调用存储过程,并返回存储过程返回值的通用方法
*
*
*
(1)操作还是更新
(2)操作
*
*/
publicintProcReturnValue(stringprocName,SqlParameter[]cmdparam,intDataOpType)
{
SqlConnectionsqlconn=newSqlConnection(ConnectionString);
try
{
if(sqlconn.State!
=ConnectionState.Open)
{
sqlconn.Open();
}
SqlCommandsqlcmd=newSqlCommand();
sqlcmd.Connection=sqlconn;
sqlcmd.CommandText=procName;
sqlcmd.CommandType=CommandType.StoredProcedure;
if(cmdparam!
=null)
{
foreach(SqlParameterparamincmdparam)
sqlcmd.Parameters.Add(param);
}
sqlcmd.Parameters.Add(newSqlParameter("@ReturnValue",SqlDbType.TinyInt));
sqlcmd.Parameters["@ReturnValue"].Direction=ParameterDirection.ReturnValue;
if(DataOpType==1)
{
sqlcmd.ExecuteScalar();
}
if(DataOpType==2)
{
sqlcmd.ExecuteNonQuery();
}
returnConvert.ToByte(sqlcmd.Parameters["@ReturnValue"].Value);
}
catch
{
throw;
}
finally{
sqlconn.Close();
}
}
}
至此,数据库通用访问类创建完毕。
我们可以用此类完成几乎所有的数据库操作。
2.2系统主界面设计与功能实现
(1)界面设计的基本要求
①界面设计要完整的体现用户的功能需求,并且美观大方。
②界面设计的交互操作过程符合用户的习惯性工作过程。
(2)系统主界面设计
在stuInfoManage项目中将Form1.cs重命名为MainForm.cs,并参照表格2.2-1的说明设置MainForm窗体的属性。
属性名
设置
IsMdiContainer
True
Text
学生信息管理系统
StartPosition
CenterScreen
WindowState
Maximized
表格2.2-1:
主窗体主要参数设置
(3)系统菜单设计
根据需求,系统需要在主窗体上创建一个菜单系统来引导用户的操作,至于菜单系统中的各级菜单显示字符以及命名参见表格2.2-2说明。
主菜单
子菜单
命名
系统管理
SystemManageMenuItem
系统登陆
LoginInMenuItem
注销
LoginOutMenuItem
退出
SystemExitMenuItem
数据查询
DataQueryMenuItem
学生基本信息浏览
StuBasicInfoQueryMenuItem
学生成绩信息查询
StuGradeInfoQueryMenuItem
课程成绩信息查询
CourseGradeQueryMenuItem
数据添加
DataAddMenuItem
学生基本信息添加
StuBasicInfoInsertMenuItem
数据更新
DataUpdateMenuItem
学生基本信息更新
StuBasicInfoUpdateMenuItem
数据删除
DataDeleteMenuItem
学生基本信息删除
StuBasicInfoDeleteMenuItem
帮助
HelpMenuItem
关于本系统
AboutSystemMenuItem
表格:
2.2-2菜单系统主要参数设置
(4)系统菜单功能初始状态的设定
由于该系统需要合法用户登陆成功后才能操作相应的系统主要功能,所以系统的主要功能的初始状态是不可用的。
此外,当系统登录成功后需要打开系统主要功能锁定。
为了实现该功能以及方便以后操作,首先在MainForm类中添加以下两个私有方法:
//将系统主要功能调用的菜单锁定的方法
privatevoidMenuStatusOFF()
{
DataQueryMenuItem.Enabled=false;
DataAddMenuItem.Enabled=false;
DataUpdateMenuItem.Enabled=false;
DataDeleteMenuItem.Enabled=false;
}
//打开系统主要功能锁定状态的方法
privatevoidMenuStatusOn()
{
DataQueryMenuItem.Enabled=true;
DataAddMenuItem.Enabled=true;
DataUpdateMenuItem.Enabled=true;
DataDeleteMenuItem.Enabled=true;
}
然后,双击MainForm窗体类的Load事件,在该事件中添加如下代码:
MenuStatusOFF();
(5)“注销”功能的实现
功能:
将系统主要功能设置为锁定状态,以方便其他用户登陆使用。
具体操作:
选中“注销”菜单,在注销菜单的Click事件中添加如下代码。
MenuStatusOFF();
(6)“退出”功能的实现
当系统退出时,需要提示是否真的退出等提示选项等,实现该功能在MainForm窗体类中进行如下操作:
①在“退出”菜单的Click事件中添加如下代码:
this.Close();
②在MainForm窗体类的FormClosing事件中添加如下代码:
DialogResultmgr=MessageBox.Show("您确定要退出学生信息管理系统吗?
",
"信息提示",
MessageBoxButtons.OKCancel,MessageBoxIcon.Question,
MessageBoxDefaultButton.Button1);
if(mgr==DialogResult.Cancel)
e.Cancel=true;
至此,系统主界面以及菜单系统的主要设计任务已经完毕。
2.3登录窗体的设计与功能实现
(1)功能描述
该步骤要实现两个功能:
1、点击“系统管理”主菜单下“系统登录”功能选项,打开“系统登陆”窗体;在该窗体处于打开状态时,我们不能操作主界面包括系统菜单的所有功能,除非关闭该窗体以后,才能继续操作;
2、系统启动完成后,系统主要功能处于不可用状态,当登陆成功后,打开功能锁定。
在本案例中,解决第一个问题的方法是使用模式对话框,解决第二个问题的方法是在登陆窗体中设置一个“系统菜单状态”变量(SysMenuStatus),通过该变量的真假来判断是否打开系统的功能锁定。
(2)流程图
针对功能描述,我们绘制系统登录功能的操作流程图如图2.3-1所示。
图2.3-1:
“系统登录”功能实现流程图
(3)数据库设计
本窗体主要功能的实现所涉及的用户登陆合法性验证采用带返回值的存储过程来实现。
具体操作过程为:
在SQLServer查询分析器中输入以下代码后并运行,创建存储过程LoginJudge,用于判断登陆用户的合法性验证。
UsestuInfoManage
Ifexists(select*fromsysobjectswherename=‘LoginJudge’andtype=‘P’)
DropprocedureLoginJudge
go
createprocedureLoginJudge
(
@userNamenvarchar(100),
@passWordvarchar(100)
)
as
ifnotexists(select*fromadminwhereuserName=@userName)
return1--表示不存在该用户
else
begin
ifnotexists(select*fromadminwhereuserName=@userNameand[password]=@passWord)
return2--表示密码错误
else
return3--表示登陆成功
end
GO
代码输入完毕后点击运行按钮,生成LoginJudge存储过程。
(4)界面设计
首先,在stuInfoManage项目中添加一个Windows窗体,将其窗体类名改为:
SystemLoginForm,设置该窗体的属性Text为“系统登录”,并添加一个公共数据成员:
publicBooleanSysMenuStatus=false;
其次,在该“系统登录”窗体上添加必要控件并设置相关属性,具体设置参照表格14.2.3-1说明。
控件类型
命名
属性
Lable1
采用系统默认
Text:
系统登陆
Lable2
采用系统默认
Text:
用户名:
Lable3
采用系统默认
Text:
密码:
ComboBox
U
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 项目 学生 信息管理 系统