1、第11章 综合案例:学生信息管理系统第第11章章 综合案例:学生综合案例:学生信息管理系统信息管理系统11.1 需求概述需求概述11.2 系统总体设计系统总体设计11.3 系统的实现系统的实现第11章 综合案例:学生信息管理系统 学习目标学习目标 了解学生信息管理系统的需求 掌握学生信息管理系统的设计方法 实现学生信息管理系统 本章将以大家熟悉的学生信息管理系统为案例背景,采用软件工程化的思想和流行的三层开发模式,将本书所学到的知识融入到本案例中,达到学完本书内容就可以做项目的目的。第11章 综合案例:学生信息管理系统11.1 需需 求求 概概 述述 随着学校的规模不断扩大,学生数量急剧增加,
2、有关学生的各种信息量也成倍增长。面对庞大的信息量,就需要建立学生信息管理系统来提高学生管理工作的效率。通过这样的系统,可以做到信息的规范管理、科学统计和快速的查询,从而减少管理方面的工作量。根据和软件用户的沟通,确定学生信息管理系统主要的功能需求如下:(1)有关学籍等信息的输入,包括学生基本信息、所在班级、所学课程和成绩等。第11章 综合案例:学生信息管理系统 (2)学生信息的查询,包括学生基本信息、所在班级、已学课程、所有成绩和奖罚信息等。(3)学生信息(包括奖罚信息)修改。(4)班级管理信息的输入,包括班级设置、年级信息和班级辅导员等。(5)班级管理信息的查询。(6)班级管理信息的修改。(
3、7)学校基本课程信息的输入。(8)基本课程信息的修改。(9)学生课程的设置和修改。(10)学生成绩信息的输入。第11章 综合案例:学生信息管理系统 (11)学生成绩信息的修改。(12)学生成绩信息的查询。(13)学生成绩的报表打印。(14)用户登录信息的添加、修改和删除等。(15)用户登录的密码修改。(16)数据库文件的备份。第11章 综合案例:学生信息管理系统11.2 系统总体设计系统总体设计 了解了项目的需求后,下面将根据需求对该项目进行功能模块设计和数据模块的设计。本项目采用了三层设计模式,分别为界面表现层、数据访问层、数据层,如图11-1所示。11.2.1 功能模块设计功能模块设计 系
4、统开发的总体任务是实现信息关系的系统化、规范化和自动化。系统的结构关系如图11-2所示。系统的结构关系图是系统的总体功能分析,是在系统开发的总体任务的基础上完成的。第11章 综合案例:学生信息管理系统图11-1 三层开发模式第11章 综合案例:学生信息管理系统图11-2 系统结构关系图 第11章 综合案例:学生信息管理系统 以下是上述各模块结构的描述。1系统用户管理模块系统用户管理模块 用户管理模块主要实现以下功能:用户名修改;添加用户;修改用户密码;数据库文件备份。2学籍管理模块学籍管理模块 学籍信息管理模块主要实现以下功能:注册学生学籍信息;修改学生学籍信息;查询学生学籍信息。第11章 综
5、合案例:学生信息管理系统 3课程班级信息管理模块课程班级信息管理模块 班级信息主要实现以下功能:添加班级及辅导员信息;修改班级及辅导员信息;查询班级及辅导员信息。课程信息主要实现以下功能:添加班级课程信息;查询班级课程信息。4成绩管理模块成绩管理模块 成绩管理模块主要实现以下功能:添加学生成绩;修改学生成绩;第11章 综合案例:学生信息管理系统 查询个人成绩;查询班级成绩;打印班级成绩。5学生奖罚信息管理模块学生奖罚信息管理模块 奖罚信息模块主要实现以下功能:添加学生奖罚信息;修改学生奖罚信息;查询学生奖罚信息。11.2.2 数据模块设计数据模块设计 1数据处理流程数据处理流程 系统的总体处理
6、数据流程如图11-3所示。第11章 综合案例:学生信息管理系统图11-3 处理流程图 第11章 综合案例:学生信息管理系统2数据结构设计数据结构设计 根据上述数据处理流程,在本项目中的数据库采用了Microsoft推出的Access数据库,这是微软集成到Office中的一个桌面数据库,能够快速方便地和Office的其他套件综合使用。由于Access具有显著的简易性和有效性,大量的桌面数据库系统都采用Access作为后台数据库。使用Access的好处还在于,如果你的系统扩展到Client/Server模式,就可以使用Microsoft的数据库服务器软件SQL Server,此时,程序只需要简单地
7、修改一下链接(ADO的数据源)就可以了,这将为程序的平滑扩展提供非常便利的条件。第11章 综合案例:学生信息管理系统 1)本系统中所涉及到的主要实体 (1)登录信息表:用户名,密码。(2)学生信息表:学号,姓名,性别,出生年月,民族,籍贯,家庭住址,电话,入学年份,班名,专业名,政治面貌,职务,宿舍住址,班内序号,如图11-4所示。(3)课程表:班级,课程,如图11-5所示。(4)学生成绩表:班级,学号,姓名,性别,课程名称,成绩,备注,如图11-4所示。(5)班级辅导员信息表:班级名称,辅导员,电话,如图11-5所示。(6)学生奖罚信息表:学号,姓名,班级,奖罚,日期,备注,如图11-6所示
8、。第11章 综合案例:学生信息管理系统图11-4 学生信息表和学生成绩表第11章 综合案例:学生信息管理系统图11-5 班级辅导员信息表和课程表第11章 综合案例:学生信息管理系统图11-6 学生奖罚信息表和登录信息表 第11章 综合案例:学生信息管理系统 2)本系统所涉及到的主要结构设计 (1)逻辑结构设计。在数据库的逻辑结构中分别定义了每个表中所需的字段信息,这是数据库设计中关键的一步。(2)物理结构设计。系统的物理结构具体由数据库来设计与生成,此处略。(3)数据结构与程序的关系。系统的数据结构由标准数据库语言SQL生成。(4)实体联系图设计如图11-7所示。第11章 综合案例:学生信息管
9、理系统图11-7 实体联系图 第11章 综合案例:学生信息管理系统11.3 系系统统的的实实现现 本部分根据功能模块和数据模块的设计,在Visual Studio.NET 2005中实现该系统。主要介绍了该系统各模块的界面以及相应功能实现的源代码与分析。图11-8 项目源文件结构在各模块进行介绍之前,关于本项目的一些配置说明如下:(1)为了方便使用该系统,本项目采用了小型桌面数据库Access。在为读者提供的源代码文件中。本项目的数据库文件放在项目的Bin文件夹下面的Debug目录下,文件名为MyDb.MDB。(2)本项目的源代码文件结构如图11-8所示。第11章 综合案例:学生信息管理系统图
10、11-8 项目源文件结构第11章 综合案例:学生信息管理系统 文件说明如下:其中Program.cs 类文件为主类文件,包含了程序启动的主方法Main()。本项目采用了三层开发模式,即数据层、数据访问层和界面层。其中:数据层就是数据库文件,里面保存了本项目所有的数据。数据访问层是介于界面层和数据层之间的桥梁,其中保含了连接数据库和插入、更新、删除、检索数据的接口。图11-8中的MyData.cs就是数据访问层。界面层主要是用来为用户提供输入和显示数据的接口,它主要通过调用数据访问层提供的接口来操作数据库。图11-8中带窗体小图标的文件都是界面层。第11章 综合案例:学生信息管理系统 数据访问层
11、Mydata.cs类的源代码如下:using System;using System.Data;using System.Data.OleDb;using System.Windows.Forms;namespace 学生信息管理系统 public class MyData /定义连接字符串 private string strDSN;/定义数据库连接对象 private OleDbConnection myConn;/构造函数实现打开数据库连接第11章 综合案例:学生信息管理系统 public MyData()strDSN=Provider=Microsoft.Jet.OLEDB.4.0;D
12、ataSource=mydb.mdb;myConn=new OleDbConnection(strDSN);myConn.Open();/利用DataReader对象检索数据 public OleDbDataReader getDataReader(String strSQL)try OleDbCommand myCmd=new OleDbCommand(strSQL,myConn);OleDbDataReader datareader=myCmd.ExecuteReader();return datareader;第11章 综合案例:学生信息管理系统 catch(Exception e)Me
13、ssageBox.Show(e.Message,数据库操作失败,MessageBoxButtons.OK,MessageBoxIcon.Information);return null;/更新数据库 public Boolean updateSql(String strSQL)OleDbCommand myCmd=new OleDbCommand(strSQL,myConn);try第11章 综合案例:学生信息管理系统 myCmd.ExecuteNonQuery();return true;catch(Exception e)MessageBox.Show(e.Message,提示,Messa
14、geBoxButtons.OK,MessageBoxIcon.Information);return false;/创建数据集第11章 综合案例:学生信息管理系统 public DataSet getDataSet(string str)OleDbDataAdapter da=new OleDbDataAdapter(str,myConn);DataSet ds=new DataSet();da.Fill(ds,);return ds;/关闭数据库连接 public void closeConnection()try myConn.Close();第11章 综合案例:学生信息管理系统 catc
15、h(Exception sqle)Console.WriteLine(数据库关闭失败);这个类是一个公共模块,为其他模块提供数据库访问的服务。本项目的界面有别于传统界面,这是由于在本项目的界面设计中使用了皮肤组件。该皮肤组件为SuniSoft.IrisSkin.,读者可以从网上下载该组件,然后添加到工具箱中。从工具箱中拖到界面上后,设置皮肤,不用写一句代码,所有属于该项目的界面都会重新穿上新“衣裳”。第11章 综合案例:学生信息管理系统11.3.1 系统登录模块系统登录模块 系统登录模块的主要功能是为了提高系统的安全性管理,需要用户提供正确的用户名和帐号才能登录本系统进行使用。本系统的用户名和
16、密码保存在 数据库的“登录信息表”中。在本书提供的项目源代码中,可以找到该数据库。默认的用户名和密码分别是“admin”和“555”,通过正确的用户名和密码就可以登录到系统,如图11-9所示。第11章 综合案例:学生信息管理系统图11-9 登录界面第11章 综合案例:学生信息管理系统 Login.cs源代码如下:public partial class Login:Form /登录窗体 public Login()InitializeComponent();/初始化 private void btnCancel_Click(object sender,EventArgs e)/取消按钮 App
17、lication.Exit();/退出程序 private void btnLogin_Click(object sender,EventArgs e)第11章 综合案例:学生信息管理系统 FrmMain Fm=(FrmMain)this.Owner;MyData mydata=new MyData();/为自定义的数据库表读写类 String str=“select*from 登录信息表 where 用户名 =+this.txtUsername.Text+and 密码=+this.txtPassword.Text+;/SQL语名:查询登录信息表中的符合规定的数据 OleDbDataReade
18、r objDbr=mydata.getDataReader(str);/mydata的一个方法,返回OleDbDataReader对象,用来读写数据库 if(objDbr.HasRows)/判断符合规定的记录是否存在 while(objDbr.Read()/利用循环逐行读取数据 string strusername=objDbr用户名.ToString().Trim();/取出当前所指记录的用户名第11章 综合案例:学生信息管理系统 string username=this.txtUsername.Text;/用户名文本框的数据 if(username=strusername)/文本框数据与登
19、录信息表的用户名进行比较 string stuPSW=objDbr密码.ToString().Trim();/取出表中密码 string psw=this.txtPassword.Text;/密码文本框数据 if(stuPSW=psw)/同理:当比较结果为真时,就打开主界面 Fm.UserName=strusername;Fm.PassWord=stuPSW;Fm.Show();this.Close();第11章 综合案例:学生信息管理系统 else /进行提示,并把文本框清空,重新输入 MessageBox.Show(密码或用户名错误,警告,MessageBoxButtons.OK,Mess
20、ageBoxIcon.Error);txtUsername.Text=;txtPassword.Text=;txtUsername.Focus();mydata.closeConnection();/关闭数据库连接 第11章 综合案例:学生信息管理系统11.3.2 系统主模块系统主模块 系统主模块是本系统的应用界面,在本界面上集成了本系统的所有功能,共有八个功能菜单和14个子菜单(功能模块),从而实现了本系统从用户管理、缴费管理、课程管理、成绩管理等系统的具体功能,同时,在系统管理模块中可以完成对本系统的安全性管理,如图11-10所示。第11章 综合案例:学生信息管理系统图11-10 系统主界
21、面第11章 综合案例:学生信息管理系统 FrmMain.cs源代码如下:public partial class FrmMain:Form /此为主界面的源代码 public string UserName;public string PassWord;public FrmMain()InitializeComponent();private void FrmMain_Load(object sender,EventArgs e)Login log=new Login();log.Owner=this;this.Visible=false;log.Show();第11章 综合案例:学生信息管理
22、系统 private void mniRegisterQuery_Click(object sender,EventArgs e)FrmRegister objFR=new FrmRegister();/此为调用新生注册窗体 objFR.MdiParent=this;objFR.Show();private void MenuItem10_Click(object sender,EventArgs e)FrmCourse objFC=new FrmCourse();/此为调用课程设置窗体 objFC.MdiParent=this;objFC.btnCanceladd.Visible=false
23、;objFC.Show();第11章 综合案例:学生信息管理系统 private void MenuItem11_Click(object sender,EventArgs e)FrmClass objFCL=new FrmClass();/此为调用班级设置窗体 objFCL.MdiParent=this;objFCL.Show();private void MenuItem7_Click(object sender,EventArgs e)FrmPerson objFP=new FrmPerson();/此为调用学生信息窗体 objFP.MdiParent=this;objFP.Show()
24、;第11章 综合案例:学生信息管理系统 private void mniExit_Click(object sender,EventArgs e)Application.Exit();/结束程序运行 private void mniLogin_Click(object sender,EventArgs e)FrmAlterPassword objFAP=new FrmAlterPassword(UserName,PassWord);/调用修改用户窗体 objFAP.MdiParent=this;objFAP.Show();第11章 综合案例:学生信息管理系统 private void Menu
25、Item2_Click(object sender,EventArgs e)FrmAddUser objFAD=new FrmAddUser();/调用添加用户窗体 objFAD.MdiParent=this;objFAD.Show();private void MenuItem3_Click(object sender,EventArgs e)FrmDelUser objFDU=new FrmDelUser();/调用删除用户窗体 objFDU.MdiParent=this;objFDU.Show();第11章 综合案例:学生信息管理系统 private void MenuItem14_Cl
26、ick(object sender,EventArgs e)/数据库的备份 FileInfo file=new FileInfo(Application.StartupPath+mydb.mdb);/设置要备份的数据库所在路径 SaveFileDialog1.DefaultExt=mdb;/设置相关数据库信息 SaveFileDialog1.FileName=mydb;SaveFileDialog1.Title=数据库文件备份.;SaveFileDialog1.Filter=Access files(*.mdb)|*.mdb;SaveFileDialog1.InitialDirectory=c
27、:;SaveFileDialog1.OverwritePrompt=true;if(SaveFileDialog1.ShowDialog()=DialogResult.OK)/选择要保存新数据库的路径第11章 综合案例:学生信息管理系统 file.CopyTo(SaveFileDialog1.FileName,true);/此方法对数据库进行备份 MessageBox.Show (数据库备份成功,提,MessageBoxButtons.OK,MessageBoxIcon.Information);else MessageBox.Show(找不到数据库文件,任务无法完成,警告,MessageBo
28、xButtons.OK,MessageBoxIcon.Error);第11章 综合案例:学生信息管理系统 private void MenuItem6_Click(object sender,EventArgs e)frmPrize objPrize=new frmPrize();/此为调用学生奖罚信息窗体 objPrize.MdiParent=this;objPrize.Show();private void MenuItem8_Click(object sender,EventArgs e)QueryResult objQR=new QueryResult();/此为调用班级信息窗体 ob
29、jQR.MdiParent=this;objQR.Show();第11章 综合案例:学生信息管理系统 private void MenuItem9_Click(object sender,EventArgs e)new InputBox().Show();private void MenuItem12_Click(object sender,EventArgs e)Result objResult=new Result();/此为调用成绩录入窗体 objResult.MdiParent=this;objResult.Show();第11章 综合案例:学生信息管理系统11.3.3 用户管理模块用
30、户管理模块 用户管理模块是本系统的安全性设置模块,对用户进行管理。此模块主要有添加、删除、修改功能,同时还兼有数据库备份功能,如图11-11、11-12所示。第11章 综合案例:学生信息管理系统图11-11 添加用户 第11章 综合案例:学生信息管理系统 图 11-12 删除用户第11章 综合案例:学生信息管理系统 下面的三个事件处理过程分别是添加用户、修改用户密码和删除用户的实现源代码:private void btnSubmit_Click(object sender,EventArgs e)/此为添加用户的源代码 try string str=select 用户名from 登录信息表 w
31、here用户名=+txtUsername.Text+;/SQL语句主要用来查找登录信息表是否存在有此用户 OleDbDataReader objDbr=mydata.getDataReader(str);if(objDbr.HasRows=true)落成 /存在则弹出警告,取消注册第11章 综合案例:学生信息管理系统 MessageBox.Show(用户名已经存在);this.txtUsername.Text=;this.txtPasswordone.Text=;this.txtPasswordtwo.Text=;txtUsername.Focus();objDbr.Close();catch
32、(Exception ex)MessageBox.Show(ex.Message,警告,MessageBoxButtons.OK,MessageBoxIcon.Error);第11章 综合案例:学生信息管理系统 if(this.txtPasswordone.Text.Trim()=)return;if(this.txtPasswordone.Text!=this.txtPasswordtwo.Text)MessageBox.Show(两次密码输入不一致);this.txtUsername.Text=;this.txtPasswordone.Text=;this.txtPasswordtwo.T
33、ext=;txtPasswordone.Focus();string strinsert=insert into 登录信息表(用户名,密码)values(+this.txtUsername.Text+,+this.txtPasswordone.Text+);/此语句主要用于添加用户第11章 综合案例:学生信息管理系统 if(mydata.updateSql(strinsert)MessageBox.Show(注册成功);this.Close();private void btnSubmit_Click(object sender,EventArgs e)/此方法主要用于修改用户密码 if(Pa
34、ssWord=txtPassword.Text)string str=update 登录信息表 set 密码=+txtNewPassword.Text+where 用户名=+txtname.Text+;/更新密码的SQL语句 if(mydata.updateSql(str)第11章 综合案例:学生信息管理系统 MessageBox.Show(密码修改成功!(如需再修改请重新登录),“提示,MessageBoxButtons.OK,MessageBoxIcon.Information);this.Close();else MessageBox.Show(原密码输入错误,请重新输入!,提示,Mes
35、sageBoxButtons.OK,MessageBoxIcon.Information);txtPassword.Text=;txtNewPassword.Text=;txtPassword.Focus();第11章 综合案例:学生信息管理系统 private void btnDel_Click(object sender,EventArgs e)/删除用户的源码 string str=“select*from 登录信息表 where 用户名 =+cmbAlluser.Text+;string password=;OleDbDataReader objDbr=mydata.getDataRe
36、ader(str);while(objDbr.Read()password=objDbr密码.ToString().Trim();if(password=txtPassword.Text)string strdelete=delete from 登录信息表 where 用户名=+cmbAlluser.Text+;/SQL的删除语句第11章 综合案例:学生信息管理系统 if(mydata.updateSql(strdelete)MessageBox.Show(用户删除成功,提示,MessageBoxButtons.OK,MessageBoxIcon.Information);txtPasswor
37、d.Text=;FrmDelUser_Load(sender,e);else MessageBox.Show(“密码错误,不允许删除”,“警告,MessageBoxButtons.OK,MessageBoxIcon.Error);txtPassword.Text=;FrmDelUser_Load(sender,e);第11章 综合案例:学生信息管理系统11.3.4 学籍信息管理模块学籍信息管理模块 学籍信息管理模块主要由学籍查询、学籍修改、学生个人信息等窗体组成,达到学生信息管理的一体化,如图11-13、11-14所示。第11章 综合案例:学生信息管理系统图11-13 新生注册第11章 综合案
38、例:学生信息管理系统图11-14 学生个人信息查询 第11章 综合案例:学生信息管理系统 下面的两个事件处理过程和三个方法实现了新生注册、查询学生基本信息、查询学生成绩信息和查询学生奖罚信息的实现源代码。private void btnConfirm_Click(object sender,EventArgs e)/此方法为注册新生信息 if(MyDUpDown.Text=)MessageBox.Show(请选择入学年份!,提示,MessageBoxButtons.OK,MessageBoxIcon.Information);MyDUpDown.Focus();return;/此处代码省略,主
39、要用于判断文本框是否为空 第11章 综合案例:学生信息管理系统 string birth=ComboBox1.Text+-+ComboBox2.Text;MyData mydata=new MyData();String strsql=“insert into 学生信息表(学号,姓名,性别,出生年月,民族,籍 贯,家庭住址,电话,入学年份,班名,专业名,政治面貌,职务,宿舍住址,班内 序号)values(+txtID.Text+,+txtName.Text+,+cmbSex.Text+,+birth+,+txtNation.Text+,+txtzg.Text+,+txtFamilyAddr.T
40、ext+,+txtPhone.Text+,+MyDUpDown.Text+,+cmbClass.Text+,+cmbProfession.Text+,+cmbVisage.Text +,+txtDuty.Text+,+txtbedroomaddr.Text+,+txtClassnumber.Text+);/此SQL语句主要用于在学生信息表中插入一条新的学生信息记录第11章 综合案例:学生信息管理系统 if(mydata.updateSql(strsql)/保存数据,保存成功返回一个true MessageBox.Show(“记录插入成功”,“提示,MessageBoxButtons.OK,Me
41、ssageBoxIcon.Information);txtID.Text=;/对输入文本框进行清空 txtName.Text=;txtNation.Text=;txtDuty.Text=;txtzg.Text=;txtPhone.Text=;txtClassnumber.Text=;txtFamilyAddr.Text=;txtbedroomaddr.Text=;第11章 综合案例:学生信息管理系统/下边的方法为学生个人信息的查询public void baseInfo_load()/学生基本信息 string str=“select 学号,入学年份,姓名,性别,出生年月,电话,民族,政治 面
42、貌,职务,班名,专业名,家庭住址,宿舍住址 from 学生信息表 where 学号=+txtIdsearch.Text+;OleDbDataReader objDbr=mydata.getDataReader(str);while(objDbr.Read()txtyear.Text=objDbr入学年份.ToString().Trim();txtname.Text=objDbr姓名.ToString().Trim();txtsex.Text=objDbr性别.ToString().Trim();txtbrith.Text=objDbr出生年月.ToString().Trim();txtPhon
43、e.Text=objDbr电话.ToString().Trim();txtNation.Text=objDbr民族.ToString().Trim();第11章 综合案例:学生信息管理系统 txtVisage.Text=objDbr政治面貌.ToString().Trim();txtDuty.Text=objDbr职务.ToString().Trim();txtclass.Text=objDbr班名.ToString().Trim();txtProfession.Text=objDbr专业名.ToString().Trim();txtFamilyaddr.Text=objDbr家庭住址.ToS
44、tring().Trim();txtBedroomaddr.Text=objDbr宿舍住址.ToString().Trim();public void dgResult_load()/学生成绩 dgResult.TableStyles.Clear();string str=select*from 学生成绩表 where 学=+txtIdsearch.Text+;DataSet Ds=mydata.getDataSet(str);dgResult.DataSource=Ds.Tables0;第11章 综合案例:学生信息管理系统 public void dgPrize_load()/学生奖罚信息
45、dgPrize.TableStyles.Clear();string str=“select*from 学生奖罚信息表 where 学号 =+txtIdsearch.Text+;DataSet Ds=mydata.getDataSet(str);dgPrize.DataSource=Ds.Tables0;private void txtpersonalsubmit_Click(object sender,EventArgs e)txtPhone.Text=;txtname.Text=;txtsex.Text=;txtbrith.Text=;第11章 综合案例:学生信息管理系统 txtyear.
46、Text=;txtNation.Text=;txtVisage.Text=;txtDuty.Text=;txtclass.Text=;txtProfession.Text=;txtFamilyaddr.Text=;txtBedroomaddr.Text=;dgResult_load();/调用显示学生成绩方法 dgPrize_load();/调用显示学生奖罚方法 baseInfo_load();/调用显示学生基本信息方法 第11章 综合案例:学生信息管理系统11.3.5 课程班级管理模块课程班级管理模块 课程班级管理模块主要包括课程设置,班级设置,班主任管理。因为本系统中有些功能模块具有相似之
47、处,所以在这里只为此模块进行一个简单的说明,如图11-15、11-16所示。第11章 综合案例:学生信息管理系统图11-15 课程设置 第11章 综合案例:学生信息管理系统图11-16 班级辅导员设置 第11章 综合案例:学生信息管理系统private void btnSearchcourse_Click(object sender,EventArgs e)/此方法用于显示课程表中的所有课程 string str=select 课程 from 课程表 where 班级=+cmbClass.Text+;OleDbDataReader objDbr=mydata.getDataReader(str
48、);lstbAllCourse.Items.Clear();while(objDbr.Read()lstbAllCourse.Items.Add(objDbr课程.ToString().Trim();/提取数据表的中课程信息写入到组合框中第11章 综合案例:学生信息管理系统private void btnModify_Click(object sender,EventArgs e)/添加辅导员 string str=update 班级辅导员信息表 set 班级名称=+cmbName.Text+,辅导员=+txtCharge.Text+,电话=+txtPhone.Text+where 班级名称=
49、+cmbName.Text+;if(mydata.updateSql(str)MessageBox.Show(记录修改成功,提示,MessageBoxButtons.OK,MessageBoxIcon.Information);add();第11章 综合案例:学生信息管理系统 private void btnDelete_Click(object sender,EventArgs e)/删除班级辅导员信息表的所指记录 if(MessageBox.Show(确定删除吗?,提示,MessageBoxButtons.OKCancel,MessageBoxIcon.Information)=Dialo
50、gResult.OK)string str=delete from 班级辅导员信息表 where 班级名称=+cmbName.Text+;if(mydata.updateSql(str)MessageBox.Show(记录删除成功,提示,MessageBoxButtons.OK,MessageBoxIcon.Information);add();第11章 综合案例:学生信息管理系统11.3.6 成绩信息管理模块成绩信息管理模块 学生成绩管理模块主要是对学生成绩进行管理。在使用学生成绩管理模块前请先进入学生信息管理模块录入相关信息,如图11-17所示。第11章 综合案例:学生信息管理系统图11-