1、重 庆 工 程 职 业 技 术 学 院C#结构化设计课程实习报告 系 名:信息工程学院班 级:软件10级(网络102)实习题目:学生成绩管理系统实习学生:井聪聪、胡荣祥指导老师:陈戈 实习时间:2011年6月26日7月1日 实习地点:4312软件实训室- 16 - 准备一、 设计目的本系统主要用于学校学生信息管理,主要任务是用计算机对学生各种信息进行日常管理。如查询、修改、增加、删除,另外还要考虑到学生选课,针对这些要求设计了学生信息管理系统,本系统主要用于学校学生信息管理,总体任务是实现学生信息关系的系统化、规范化、自动化。课题研究的主要内容及可以解决的问题:1. 有关学籍等信息的输入,包括
2、输入学生基本信息、所在班级、所学课程和成绩等。2. 学生信息的查询,包括查询学生基本信息、所在班级、已学课程和成绩等。3. 学生信息的修改。4. 班级(系别)信息管理的输入,包括输入班级(系别)设置、年级信息等。5. 班级(系别)管理的修改。6. 班级(系别)管理信息查询。7. 学校基本课程信息的输入。8. 基本课程信息的修改。9. 学生课程的设置和修改。10. 学生成绩信息的输入。11. 学生成绩信息的修改。12. 学生成绩信息的查询。二、需求分析一.开发目的:总结软件开发过程中的方法和技巧,更好的应用和数据库技术1.开发内容:开发一套学生成绩管理系统软件采取的研究方法:采用面向对象的编程,
3、结合网络和数据库技术,实现控制和管理。通过系统分析、需求分析、概要设计、详细设计、编写代码、软件测试、软件维护、经验方法总结等一系列实验方案,实验软件的开发。2.具体开发方案:分七个阶段进行:第一阶段:系统分析、需求收集和分析这一阶段首先进行系统分析,分析确定系统的规模和范围,确定软件的总体要求以及所需要的硬件和支撑软件,确定待开发软件与外界的接口,根据用户的情况确定软件对操作的要求,以及待开发软件总体上的约束和限制,完善项目计划。在这之后,这一阶段的大部分时间将被用来进行需求收集和分析。向学校管理人员及学生了解情况,确定软件系统的综合要求,分析软件系统的数据要求,导出系统的逻辑模型,修正项目
4、开发计划。采用结构化分析方法,生成数据流图、数据词典及加工逻辑说明。估计阶段跨度:2011年某月初至某月中旬第二阶段:概要设计在这一阶段将确定软件系统的结构,对全局数据结构进行设计,进行模块划分,确定每个模块的功能 接口以及模块间的调用关系。第三阶段:详细设计为每个模块设计实现的细节将成为这个阶段的主要任务,还要对局部数据结构进行设计。采用结构化设计方法。采用自顶向下逐步求精的设计方法和单入口单出口的控制结构。使得程序具有良好的结构,增强程序的可读性。详细设计时,如果不满意,须回到概要设计中重新完善设计。第四阶段:编写代码这一阶段用来根据详细设计说明书编写代码。第五阶段:软件测试这将是一个很重
5、要也将是一个很耗时间和精力的阶段。在这一阶段中将尽可能多地发现软件中的错误和缺陷。如果有错,还将退回到编设计思想用户的需求具体表现在对各种信息的提供、编辑、处理及查询统计上。这就要求数据库结构能充分满足各种信息的输入、处理和输出。该学生管理系统的数据流图描述如下:存储文档录入学生信息学生基本信息输出学生信息存储文档进入查询学生信息管理员学生课程基本信息存储文档修改学生信息课程基本信息显示信息表三、 设计要求学生管理系统的开发目的是为了实现学生课程、学籍的信息化管理。本系统需要完成的功能有:班级管理、学生管理、科目管理、课程管理、成绩管理以及系统管理员才具有的教师管理和用户管理。1.学生管理:可
6、对学生进行添加、删除、修改、查找和报表输出等功能,学生属性有:学号、姓名、性别、所属班级(系别)出生日期和备注等属性。2.课程管理:可对每一个班级的上课科目进行添加、删除、修改、查找和报表输出等功能,课程属性有:所属班级(系别)、课程名等属性。3.成绩管理:可对每一个班级的上课科目的学生成绩进行添加、删除、修改、查找和报表输出等功能,成绩属性有:学生姓名、所属班级(系别)、课程名、成绩、备注等属性。4.系统模块的实现:在系统中包括以下功能:录入学生信息、查询学生信息、修改学生信息等属性。 总体设计一、 数据库设计针对一般学生管理系统的需求,通过对学生学习过程的内容和数据流程分析,设计如下面所示
7、的数据项和数据结构:.学生基本信息(XS):学生学号(XH)、学生姓名(XM)、学生专业名(ZYM)、学生性别(XB)、学生出生日期(CSSJ)、学生专业分(ZXF)、学生备注(BZ)。.学生课程基本信息(XS_KC):学生学号(XH)、学生课程号(KCH)、学生成绩(CJ)。.课程基本信息(KC):学生课程号(KCM)、学生课程名(KCM)、学生学分(XF)二、 模块设计本系统分为四大部分1.系统主界面用户登录窗体中放置了label控件,显示登录窗体标题:学生成绩管理系统,另外还增加了三个Button控件,Buuton1,button2,button3作用分别是查询信息、修改信息、录入成绩。
8、窗体名称为界面功能介绍。主界面为进入学生管理系统各模块的入口,用户可根据上面各个模块名称单击进入各个管理模块,从而进行对系统的管理操作。学生成绩管理系统主界面主界面的代码:using System;using System.Collections.Generic;using System.ComponentModel;using System.Data;using System.Drawing;using System.Text;using System.Windows.Forms;using System.Data.SqlClient;namespace student_zhaoqing p
9、ublic partial class Form1 : Form public Form1() InitializeComponent(); private void button1_Click(object sender, EventArgs e) SearchForm searchfrm = new SearchForm(); searchfrm.ShowDialog(); private void button2_Click(object sender, EventArgs e) ModifyForm modifyfrm = new ModifyForm(); modifyfrm.Sho
10、wDialog(); private void button3_Click(object sender, EventArgs e) ScoreForm scorefrm = new ScoreForm(); scorefrm.ShowDialog(); private void Form1_Load(object sender, EventArgs e) skinEngine1.SkinFile = Calmness.ssk; 2.信息查询界面各个控件介绍:该模块主要由一个groupBox1(输入查询条件)三个label:分别设置名字为学生的学号,姓名,专业二个TextBox,分别可以输入学生
11、的学号和姓名,然后进行查询一个ComboBox下拉列表选项菜单,作用为选择要查询学生的专业一个Button按扭,起到查询的作用一个DataGridView,起到显示要查询学生的各种信息学生信息查询的运行界面如下图:学生信息查询界面学生信息查询源代码:using System;using System.Collections.Generic;using System.ComponentModel;using System.Data;using System.Drawing;using System.Text;using System.Windows.Forms;using System.Data
12、.SqlClient;namespace student_zhaoqing public partial class SearchForm : Form public SearchForm() InitializeComponent(); private string sql = ; private void SearchForm_Load(object sender, EventArgs e) string connStr = Data Source=.;database=XSCJ;Integrated Security=True; string _sql = Select XH as学号,
13、XM as 姓名,ZYM as专业,XB as性别, + CSSJ as出生日期,ZXF as总学分,BZ as 备注from XS; SqlConnection conn = new SqlConnection(connStr);conn.Open(); SqlDataAdapter sda = new SqlDataAdapter(_sql, conn); DataSet ds = new DataSet(); sda.Fill(ds); StuDGV.DataSource = ds.Tables0.DefaultView; SqlCommand cmd = new SqlCommand(
14、Select ZYM from XS, conn); SqlDataReader dr = cmd.ExecuteReader(); stuZY.Items.Add(所有专业); while (dr.Read() stuZY.Items.Add(drZYM); dr.Close(); conn.Close(); if (stuZY.Items.Count 0) stuZY.SelectedIndex = 0; private void MakeSqlStr() sql = ; if (stuXH.Text.Trim() != string.Empty) sql = and XH like% +
15、 stuXH.Text.Trim() + %; if (stuXM.Text.Trim() != string.Empty) sql += and XM like% + stuXM.Text.Trim() + %; if (stuZY.Text != 所有专业) sql += and ZYM= + stuZY.Text + ; private void button1_Click(object sender, EventArgs e) MakeSqlStr(); string connStr = Data Source=.;database=XSCJ;Integrated Security=T
16、rue; string _sql = Select XH as学号,XM as 姓名,ZYM as专业,XB as性别, + CSSJ as出生日期,ZXF as总学分,BZ as 备注from XS where 1=1 + sql; SqlConnection conn = new SqlConnection(connStr); SqlDataAdapter sda = new SqlDataAdapter(_sql, conn); DataSet ds = new DataSet(); sda.Fill(ds); StuDGV.DataSource = ds.Tables0.Default
17、View; private void stuZY_SelectedIndexChanged(object sender, EventArgs e) 3.修改删除学生信息界面控件说明:该模块主要由一个groupBox(学生信息)八个Label控件:分别设置属性名为学号,姓名,性别,出生年月,专业,总学分,备注和一个特别注意。四个TextBox,分别可以输入学生的学号,姓名,专业,总学分然后可以进行更新和删除操作一个ComboBox下拉列表选项菜单,作用为设置学生的出生日期。一个ListBox,作用为显示学生备注二个RadioButton控件,作用是设置学生的性别是男或女。一个DataGridVi
18、ew,起到显示学生的各种信息的作用。三个Button控件,其属性设置为更新,删除,取消。学生增加修改删除学生信息的运行界面如下图:添加修改删除学生信息界面更新事件:更新事件的作用是修改学生的信息,修改项为学号、姓名、性别,出生日期,专业、总学分,输入以上各项信息之后,在想修改的项目中输入想修改的内容,点击更新,就可以更新成功。更新事件的源代码如下:private void stuUpdate_Click(object sender, EventArgs e) string connStr = Data Source=.;database=XSCJ;Integrated Security=Tru
19、e; string _sql = select count(*) from XS where XH= + stuXH.Text + ; SqlConnection conn = new SqlConnection(connStr); SqlCommand cmd = new SqlCommand(_sql, conn); try conn.Open(); int cnt = (int)cmd.ExecuteScalar(); if (cnt = 1) _sql = update XS set XM = + stuXM.Text + ,ZYM= + stuZY.Text + ,ZXF=+ int
20、.Parse(stuZXF.Text) + ,BZ= + stuBZ.Text + where XH=+stuXH.Text+; else string sex = male.Checked ? 男 : 女; _sql = insert into XS values( + stuXH.Text + , + stuXM.Text + ,+ stuZY.Text + ,+ sex + ,+ stuCS.Text + , + int.Parse(stuZXF.Text) + , + stuBZ.Text + ); cmd = new SqlCommand(_sql, conn); cmd.Execu
21、teNonQuery(); ModifyForm_Load(null, null); finally conn.Close(); 删除事件:删除事件的作用是删除学生的信息,删除事件的源代码如下:private void stuDelete_Click(object sender, EventArgs e) string connStr = Data Source=.;database=XSCJ;Integrated Security=True; DialogResult ret = MessageBox.Show(确定要删除记录吗?, 删除, MessageBoxButtons.OKCance
22、l, MessageBoxIcon.Question); if (ret = DialogResult.Cancel) return; string _sql = delete from XS where XH= + stuXH.Text + ; SqlConnection conn = new SqlConnection(connStr); SqlCommand cmd = new SqlCommand(_sql, conn); try conn.Open(); int rows = cmd.ExecuteNonQuery(); ModifyForm_Load(null, null); if
23、 (rows = 1) MessageBox.Show(删除成功!, 提示, MessageBoxButtons.OK, MessageBoxIcon.Information); finally conn.Close(); 取消事件:取消事件的作用是取消操作,它的代码如下:private void stuCancel_Click(object sender, EventArgs e) this.Close(); 4.学生成绩录入界面控件说明:该模块主要由一个groupBox(学生成绩录入)六个Label控件:分别设置属性名为专业,学号,课程名,姓名,成绩,学分。 三个TextBox,分别可以输
24、入学生的姓名,成绩,学分然后可以进行更新和删除操作三个ComboBox下拉列表选项菜单,作用为显示学生的专业,学号,课程名。一个DataGridView,起到显示学生的各种信息的作用。三个Button控件,其属性设置为更新,删除,取消。学生成绩录入的运行界面如下图:学生成绩录入界面数据库连接操作代码如下:private void ScoreForm_Load(object sender, EventArgs e) string connStr = Data Source=.;database=XSCJ;Integrated Security=True; string _sql = select
25、 distinct ZYM from XS; SqlConnection conn = new SqlConnection(connStr); SqlCommand cmd = new SqlCommand(_sql, conn); try conn.Open (); SqlDataReader dr=cmd.ExecuteReader(); while (dr.Read() stuZY.Items.Add(dr0); dr.Close (); _sql = select KCM from KC; cmd=new SqlCommand (_sql ,conn); dr=cmd.ExecuteR
26、eader(); while(dr.Read () stuKCM.Items.Add(dr0); dr.Close (); finally conn.Close(); private void stuZY_SelectedIndexChanged(object sender, EventArgs e) string connStr = Data Source=.;database=XSCJ;Integrated Security=True; string _sql = select XH from XS where ZYM= + stuZY.Text + ; stuXH.Items.Clear
27、(); SqlConnection conn = new SqlConnection(connStr); SqlCommand cmd = new SqlCommand(_sql, conn); try conn.Open(); SqlDataReader dr = cmd.ExecuteReader(); while (dr.Read() stuXH.Items.Add(dr0); stuXH.SelectedIndex = 0; dr.Close(); _sql = select XS.XH as学号,XS.XM as 姓名,KC.KCM as课程名,XS_KC.CJ as成绩, + KC
28、.XF as学分,KC.XS as学时,KC.KKXQ as 开课学期 + from XS,KC,XS_KC + where XS.XH=XS_KC.XH and KC.KCH=XS_KC.KCH and XS.ZYM= + stuZY.Text + ; SqlDataAdapter sda = new SqlDataAdapter(_sql, conn); DataSet ds = new DataSet(); sda.Fill(ds); scoreDGV.DataSource = ds.Tables0.DefaultView; finally conn.Close(); StuZY(Com
29、boBox1)事件的代码如下:private void stuZY_SelectedIndexChanged(object sender, EventArgs e) string connStr = Data Source=.;database=XSCJ;Integrated Security=True; string _sql = select XH from XS where ZYM= + stuZY.Text + ; stuXH.Items.Clear(); SqlConnection conn = new SqlConnection(connStr); SqlCommand cmd =
30、 new SqlCommand(_sql, conn); try conn.Open(); SqlDataReader dr = cmd.ExecuteReader(); while (dr.Read() stuXH.Items.Add(dr0); stuXH.SelectedIndex = 0; dr.Close(); _sql = select XS.XH as学号,XS.XM as 姓名,KC.KCM as课程名,XS_KC.CJ as成绩, + KC.XF as学分,KC.XS as学时,KC.KKXQ as 开课学期 + from XS,KC,XS_KC + where XS.XH=
31、XS_KC.XH and KC.KCH=XS_KC.KCH and XS.ZYM= + stuZY.Text + ; SqlDataAdapter sda = new SqlDataAdapter(_sql, conn); DataSet ds = new DataSet(); sda.Fill(ds); scoreDGV.DataSource = ds.Tables0.DefaultView; finally conn.Close(); StuXH(ComboBox2)事件的代码如下: private void stuXH_SelectedIndexChanged(object sender
32、, EventArgs e) string connStr = Data Source=.;database=XSCJ;Integrated Security=True; string _sql= select XS.XH as学号,XS.XM as姓名,KC.KCM as课程名,XS_KC.CJ as成绩, + KC.XF as学分,KC.XS as学时,KC.KKXQ as 开课学期 + from XS,KC,XS_KC + where XS_KC.XH=+stuXH.Text+and XS_KC.XH=XS.XH and XS_KC.KCH=KC.KCH; if (stuKCM.Text
33、.Trim() != string.Empty) _sql += and KC.KCM= + stuKCM.Text + ; SqlConnection conn = new SqlConnection(connStr); SqlDataAdapter sda = new SqlDataAdapter(_sql, conn); DataSet ds = new DataSet(); sda.Fill(ds); scoreDGV.DataSource = ds.Tables0.DefaultView; StuKCM(ComboBox3)事件的代码如下: private void stuKCM_S
34、electedIndexChanged(object sender, EventArgs e) string connStr = Data Source=.;database=XSCJ;Integrated Security=True; string _sql = select XS.XH as学号,XS.XM as姓名,KC.KCM as课程名,XS_KC.CJ as成绩, + KC.XF as学分,KC.XS as学时,KC.KKXQ as 开课学期 + from XS,KC,XS_KC + where KC.KCM= + stuKCM.Text + and XS_KC.XH=XS.XH and XS_KC.KCH=KC.KCH ; if (stuXH.Text.Trim() != string.Empty) _sql += and XS.XH= + stuXH.Text + ; SqlConnection conn = new SqlConnection(connStr); SqlDataAdapter