C#Windows学生信息管理系统
系统采用三层架构编写,数据库sqlserver,软件visual studio。功能实现数据库增删查改具体如下:1. 实现管理员登录和注册。2. 实现管理员密码和信息修改。3. 实现管理员对学生信息的添加录入。4. 实现管理员对学生信息查询,有模糊查询和精确查询。5. 实现管理员对学生信息的跟新修改。6. 实现了管理员对学生信息的删除。系统用例图。
学生信息管理系统简介
中文摘要
为了提高学生信息的管理效率,本课题使用C#语言和SQL Server数据库系统开发了一个WinForm类型的学生信息管理系统对学校的学生信息进行高效管理,以提升教学质量。本系统包含管理员登录注册、管理员信息修改模块、添加学生信息模块、删除学生信息模块、查找学生信息模块、修改学生信息模块六个模块。毕业设计报告从可行性研究与项目开发计划及系统开发环境;系统需求分析;概要设计(含数据库设计)和详细设计;各功能模块的具体编码实现;系统测试;毕业设计总结六个方面进行了阐述。通过该系统的开发,对软件项目设计与开发工作的完整流程进行了实践。
关键词:学生信息管理系统,C#,SQL Server
更多源码和原文档获取:winform之家
1软件可行性研究与项目开发计划
1.1问题定义
1.2可行性分析
1.3进度计划
2.需求分析
2.1引言
2.2功能说明
2.3其他要求
操作系统:Windows
运行环境:VisualStudio
数据库环境:SQL Server
3.概要设计
3.1功能模块设计
本学生信息管理系统主要为登录注册、添加学生信息、删除学生信息、查找学生信息、修改学生信息等。
系统功能模块图如图3-1所示。
图3-1系统功能模块图
1)登陆注册功能
A.登录:输入用户名和密码登录,验证用户名和密码,进行登录。
B.注册:新建用户和密码,用来实现登陆,并有基本信息录入。
2)增删查改功能
A.管理员注册信息修改:管理员自身信息更改。
B.添加学生信息:对新生信息的录入。
C.删除学生信息:对毕业学生信息的移除。
D.查找学生信息:对学号和姓名提供查询学生信息功能。
E.修改学生信息:对学生错误信息进行修改。
3.2数据库设计
4.详细设计
4.1总体设计
(1)系统用例图
(2)系统体系结构
(3)E-R图
4.2功能模块详细分析
5.软件编码
5.1用户管理模块
(1)登录模块设计
5-1.1登录窗口
此窗体界面用于用户的登录,无账号的用户可点击注册。
登录窗口设计如下:
public static string ToMD5(string source)
{
StringBuilder sb = new StringBuilder();
MD5 md5 = MD5.Create();
byte[] data = Encoding.UTF8.GetBytes(source);
data = md5.ComputeHash(data);
foreach (var item in data)
{
sb.Append(item.ToString("x2"));
}
return sb.ToString();
}
private void Login_Load(object sender, EventArgs e)
{
txtPwd.PasswordChar = '*';
}
private void btlogin_Click(object sender, EventArgs e)
{
string no = txtAccount.Text;
string pwd = ToMD5(txtPwd.Text);
User user = new User { Mno = no, Mpwd = pwd };
bool result = ma.Login(user);
if (result)
{
this.Hide();
frmManage mainForm = new frmManage(txtAccount.Text, pwd);
mainForm.StartPosition = FormStartPosition.CenterScreen;
mainForm.Show();
}
else
{
MessageBox.Show("账号或密码错误!!!");
}
}
(2)注册模块设计
5-1.2注册窗口
此窗体界面用于用户注册。
注册界面设计如下:
private void btnRegister_Click_1(object sender, EventArgs e)
{
if (!ver.IsAccountCode(txtNo.Text))//验证帐号是否正确
{
MessageBox.Show("请输入4位账号!!!");
return;
}
if (!ver.IsChinese(txtName.Text))//验证姓名是否输入合法
{
MessageBox.Show("请输入中文姓名吧!!!");
return;
}
if (!ver.IsIDcard(txtID.Text))//验证sfz号是否正确
{
MessageBox.Show("身份证至少为18位哦!!!");
return;
}
if (!ver.IsHandset(txtPhone.Text))//验证手机号是否正确
{
MessageBox.Show("请输入正确手机号!!!");
return;
}
string no = txtNo.Text;
string name = txtName.Text;
string id = txtID.Text;
string place = txtPlace.Text;
string phone = txtPhone.Text;
string pwd = txtPwd.Text;
string pwdmd5 =ToMD5(pwd);
if (no == "" || name == "" || id == "" || place == "" || phone == "" || pwd == "")
{
MessageBox.Show("请输入完整信息!");
return;
}
User user = new User { Mno = no, Mname = name, Mid = id, Mplace = place, Mphone = phone, Mpwd = pwdmd5 };
bool result = ma.Register(user);
if (result)
{
MessageBox.Show("注册成功");
}
else
{
MessageBox.Show("账号重复!注册失败!");
}
}
5.2用户信息模块设计
5-2用户信息窗口
此窗体界面用于用户信息的更改,可按照需求更改。
用户信息界面设计如下:
private void btnSubmit_Click(object sender, EventArgs e)
{
Verification ver = new Verification();
if (!ver.IsChinese(txtName.Text))//验证姓名是否输入合法
{
MessageBox.Show("请输入中文姓名吧!!!");
return;
}
if (!ver.IsIDcard(txtID.Text))//验证sfz号是否正确
{
MessageBox.Show("身份证至少为18位哦!!!");
return;
}
if (!ver.IsHandset(txtPhone.Text))//验证手机号是否正确
{
MessageBox.Show("请输入正确手机号!!!");
return;
}
string no = txtNo.Text;
string name = txtName.Text;
string Id = txtID.Text;
string place = txtPlace.Text;
string phone = txtPhone.Text;
User user = new User {Mno=no,Mname=name,Mid=Id,Mplace=place,Mphone=phone};
bool result = ma.Update(user);
if (result)
{
MessageBox.Show("修改成功");
}
else
{
MessageBox.Show("修改失败");
}
}
5.3用户修改密码模块设计
5-3修改密码窗口
此窗体界面用于管理员密码修改
修改密码界面设计如下:
private void skinButton1_Click(object sender, EventArgs e)
{
if(txtPwd.Text == ""||txtNewPwd.Text == "")
{
MessageBox.Show("请输入密码!!!");
return;
}
string str= ma.SelectOne(SendAccount).DataSet.Tables[0].Rows[0]["密码"].ToString();
if (str == ToMD5(txtPwd.Text))
{
string newpwd = ToMD5(txtNewPwd.Text);
string no = txtaccount.Text;
User user = new User { Mno = no, Mpwd = newpwd };
bool result = ma.UpdatePwd(user);
if (result)
{
MessageBox.Show("修改成功,请重新登录");
this.Hide();
Login mainForm = new Login();
mainForm.StartPosition = FormStartPosition.CenterScreen;
mainForm.Show();
}
else
{
MessageBox.Show("修改失败");
}
}
else
{
MessageBox.Show("原密码错误!!!");
}
}
5.4添加学生信息管理模块设计
5-4添加学生窗口
此窗体界面用于学生信息的添加,实现对学生信息的添加
学生信息的添加界面设计如下:
private void btnA_Click(object sender, EventArgs e)
{
Verification ver = new Verification();
if (!ver.IsChinese(txtName.Text))//验证姓名是否输入合法
{
MessageBox.Show("请输入中文姓名吧!!!");
return;
}
if (!ver.IsIDcard(txtID.Text))//验证sfz号是否正确
{
MessageBox.Show("身份证至少为18位哦!!!");
return;
}
if (!ver.IsHandset(txtPhone.Text))//验证手机号是否正确
{
MessageBox.Show("请输入正确手机号!!!");
return;
}
try
{
string name = txtName.Text;
string sex;
if (rdobtn男.Checked)
{
sex = rdobtn男.Text;
}
else
{
sex = rdobtn女.Text;
}
string id = txtID.Text;
string Cla = cboxClass.Text;
string phone = txtPhone.Text;
string place = txtPlace.Text;
Student stu = new Student {stuName = name, stuSex = sex, stuID = id, stuClass = Cla, stuPhone = phone, stuPlace = place };
bool result = stuma.Add(stu);
if (result)
{
MessageBox.Show("添加成功");
getAll();
}
else
{
MessageBox.Show("添加失败");
}
Clearbox();
}
catch (Exception ex)
{
MessageBox.Show(ex.Message);
}
}
5.5删除学生信息模块设计
5-5删除学生信息窗口
此窗体界面用于学生信息的删除。
窗口设计如下:
private void btnSubmitDelect_Click(object sender, EventArgs e)
{
int no =int.Parse( txtDeleteNo.Text);
Student stu = new Student { stuNo = no};
bool result = stuma.Delete(stu);
if (result)
{
MessageBox.Show("删除成功");
}
else
{
MessageBox.Show("删除失败");
}
getAll();
txtDeleteNo.Text = "";
Clearbox();
}
5.6查询学生信息模块设计
5-6查询学生信息窗口
此窗体界面用于查询学生的信息。
窗口设计如下:
private void btnSelectNo_Click(object sender, EventArgs e)
{
try
{
DataGridView1.DataSource = stuma.SelectOne(txtSelectNo.Text);
}
catch (Exception ex)
{
}
}
private void btnSelectSure_Click(object sender, EventArgs e)
{
DataGridView1.DataSource = stuma.SelectOnes(txtSelectName.Text);
}
5.7修改学生信息模块设计
5-7修改学生信息窗口
此窗体界面用于修改学生的信息。
窗口设计如下:
private void btnSubmitUpdate_Click_1(object sender, EventArgs e)
{
Verification ver = new Verification();
if (!ver.IsChinese(txtName.Text))//验证姓名是否输入合法
{
MessageBox.Show("请输入中文姓名吧!!!");
return;
}
if (!ver.IsIDcard(txtID.Text))//验证sfz号是否正确
{
MessageBox.Show("身份证至少为18位哦!!!");
return;
}
if (!ver.IsHandset(txtPhone.Text))//验证手机号是否正确
{
MessageBox.Show("请输入正确手机号!!!");
return;
}
int no = int.Parse(stuNo);
string name = txtName.Text;
string sex = "";
if (rdobtn男.Checked)
{
sex = rdobtn男.Text;
}
else
{
sex = rdobtn女.Text;
}
string Id = txtID.Text;
string bj = cboxClass.Text;
string phone = txtPhone.Text;
string place = txtPlace.Text;
Student stu = new Student { stuNo = no,stuName = name, stuSex = sex, stuID = Id, stuClass = bj, stuPhone = phone, stuPlace = place };
bool result = stuma.Update(stu);
if (result)
{
MessageBox.Show("修改成功");
getAll();
}
else
{
MessageBox.Show("修改失败");
}
Clearbox();
}
6.测试
6.1测试计划
6.2测试用例设计及执行
6.3测试小结
7. 总结
更多推荐
所有评论(0)