资源描述
重 庆 工 程 职 业 技 术 学 院
《C#结构化设计》
课程实习报告
系 名:信息工程学院
班 级:软件10级(网络102)
实习题目:学生成绩管理系统
实习学生:井聪聪、胡荣祥
指导老师:陈戈
实习时间:2011年6月26日~7月1日
实习地点:4312软件实训室
- 16 -
准备
一、 设计目的
本系统主要用于学校学生信息管理,主要任务是用计算机对学生各种信息进行日常管理。如查询、修改、增加、删除,另外还要考虑到学生选课,针对这些要求设计了学生信息管理系统,本系统主要用于学校学生信息管理,总体任务是实现学生信息关系的系统化、规范化、自动化。
课题研究的主要内容及可以解决的问题:
1. 有关学籍等信息的输入,包括输入学生基本信息、所在班级、所学课程和成绩等。
2. 学生信息的查询,包括查询学生基本信息、所在班级、已学课程和成绩等。
3. 学生信息的修改。
4. 班级(系别)信息管理的输入,包括输入班级(系别)设置、年级信息等。
5. 班级(系别)管理的修改。
6. 班级(系别)管理信息查询。
7. 学校基本课程信息的输入。
8. 基本课程信息的修改。
9. 学生课程的设置和修改。
10. 学生成绩信息的输入。
11. 学生成绩信息的修改。
12. 学生成绩信息的查询。
二、需求分析
一.开发目的:
总结软件开发过程中的方法和技巧,更好的应用和数据库技术
1.开发内容:开发一套学生成绩管理系统软件
采取的研究方法:采用面向对象的编程,结合网络和数据库技术,实现控制和管理。通过系统分析、需求分析、概要设计、详细设计、编写代码、软件测试、软件维护、经验方法总结等一系列实验方案,实验软件的开发。
2.具体开发方案:
分七个阶段进行:
第一阶段:系统分析、需求收集和分析
这一阶段首先进行系统分析,分析确定系统的规模和范围,确定软件的总体要求以及所需要的硬件和支撑软件,确定待开发软件与外界的接口,根据用户的情况确定软件对操作的要求,以及待开发软件总体上的约束和限制,完善项目计划。
在这之后,这一阶段的大部分时间将被用来进行需求收集和分析。向学校管理人员及学生了解情况,确定软件系统的综合要求,分析软件系统的数据要求,导出系统的逻辑模型,修正项目开发计划。
采用结构化分析方法,生成数据流图、数据词典及加工逻辑说明。
估计阶段跨度:2011年某月初至某月中旬
第二阶段:概要设计
在这一阶段将确定软件系统的结构,对全局数据结构进行设计,进行模块划分,确定每个模块的功能 接口以及模块间的调用关系。
第三阶段:详细设计
为每个模块设计实现的细节将成为这个阶段的主要任务,还要对局部数据结构进行设计。
采用结构化设计方法。采用自顶向下逐步求精的设计方法和单入口单出口的控制结构。使得程序具有良好的结构,增强程序的可读性。详细设计时,如果不满意,须回到概要设计中重新完善设计。
第四阶段:编写代码
这一阶段用来根据详细设计说明书编写代码。
第五阶段:软件测试
这将是一个很重要也将是一个很耗时间和精力的阶段。
在这一阶段中将尽可能多地发现软件中的错误和缺陷。如果有错,还将退回到编
设计思想
用户的需求具体表现在对各种信息的提供、编辑、处理及查询统计上。这就要求数据库结构能充分满足各种信息的输入、处理和输出。
该学生管理系统的数据流图描述如下:
存储文档
录入学生信息
学生基本信息
输出学生信息
存储文档
进入
查询学生信息
管理员
学生课程基本信息
存储文档
修改学生信息
课程基本信息
显示信息表
三、 设计要求
学生管理系统的开发目的是为了实现学生课程、学籍的信息化管理。本系统需要完成的功能有:班级管理、学生管理、科目管理、课程管理、成绩管理以及系统管理员才具有的教师管理和用户管理。
1.学生管理:可对学生进行添加、删除、修改、查找和报表输出等功能,学生属性有:学号、姓名、性别、所属班级(系别)出生日期和备注等属性。
2.课程管理:可对每一个班级的上课科目进行添加、删除、修改、查找和报表输出等功能,课程属性有:所属班级(系别)、课程名等属性。
3.成绩管理:可对每一个班级的上课科目的学生成绩进行添加、删除、修改、查找和报表输出等功能,成绩属性有:学生姓名、所属班级(系别)、课程名、成绩、备注等属性。
4.系统模块的实现:在系统中包括以下功能:录入学生信息、查询学生信息、修改学生信息
等属性。
总体设计
一、 数据库设计
针对一般学生管理系统的需求,通过对学生学习过程的内容和数据流程分析,设计如下面所示的数据项和数据结构:
.学生基本信息(XS):学生学号(XH)、学生姓名(XM)、学生专业名(ZYM)、学生性别(XB)、学生出生日期(CSSJ)、学生专业分(ZXF)、学生备注(BZ)。
.学生课程基本信息(XS_KC):学生学号(XH)、学生课程号(KCH)、学生成绩(CJ)。
.课程基本信息(KC):学生课程号(KCM)、学生课程名(KCM)、学生学分(XF)
二、 模块设计
本系统分为四大部分
1.系统主界面
用户登录窗体中放置了label控件,显示登录窗体标题:学生成绩管理系统,另外还增加了三个Button控件,Buuton1,button2,button3作用分别是查询信息、修改信息、录入成绩。窗体名称为界面功能介绍。主界面为进入学生管理系统各模块的入口,用户可根据上面各个模块名称单击进入各个管理模块,从而进行对系统的管理操作。
学生成绩管理系统主界面
主界面的代码:
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
{
public 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.ShowDialog();
}
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,分别可以输入学生的学号和姓名,然后进行查询
一个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.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'学号',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.Tables[0].DefaultView;
SqlCommand cmd = new SqlCommand("Select ZYM from XS", conn);
SqlDataReader dr = cmd.ExecuteReader();
stuZY.Items.Add("所有专业");
while (dr.Read())
{
stuZY.Items.Add(dr["ZYM"]);
}
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'%" + 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=True";
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.Tables[0].DefaultView;
}
private void stuZY_SelectedIndexChanged(object sender, EventArgs e)
{
}
}
}
3.修改删除学生信息界面
控件说明:
该模块主要由一个groupBox(学生信息)
八个Label控件:分别设置属性名为学号,姓名,性别,出生年月,专业,总学分,备注和一个特别注意。
四个TextBox,分别可以输入学生的学号,姓名,专业,总学分然后可以进行更新和删除操作
一个ComboBox下拉列表选项菜单,作用为设置学生的出生日期。
一个ListBox,作用为显示学生备注
二个RadioButton控件,作用是设置学生的性别是男或女。
一个DataGridView,起到显示学生的各种信息的作用。
三个Button控件,其属性设置为更新,删除,取消。
学生增加修改删除学生信息的运行界面如下图:
添加修改删除学生信息界面
更新事件:
更新事件的作用是修改学生的信息,修改项为学号、姓名、性别,出生日期,专业、总学分,输入以上各项信息之后,在想修改的项目中输入想修改的内容,点击更新,就可以更新成功。
更新事件的源代码如下:
private void stuUpdate_Click(object sender, EventArgs e)
{
string connStr = @"Data Source=.;database=XSCJ;Integrated Security=True";
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.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.ExecuteNonQuery();
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.OKCancel, 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 (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,分别可以输入学生的姓名,成绩,学分然后可以进行更新和删除操作
三个ComboBox下拉列表选项菜单,作用为显示学生的专业,学号,课程名。
一个DataGridView,起到显示学生的各种信息的作用。
三个Button控件,其属性设置为更新,删除,取消。
学生成绩录入的运行界面如下图:
学生成绩录入界面
数据库连接操作代码如下:
private void ScoreForm_Load(object sender, EventArgs e)
{
string connStr = @"Data Source=.;database=XSCJ;Integrated Security=True";
string _sql = " select 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(dr[0]);
}
dr.Close ();
_sql = " select KCM from KC";
cmd=new SqlCommand (_sql ,conn);
dr=cmd.ExecuteReader();
while(dr.Read ())
{
stuKCM.Items.Add(dr[0]);
}
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();
SqlConnection conn = new SqlConnection(connStr);
SqlCommand cmd = new SqlCommand(_sql, conn);
try
{
conn.Open();
SqlDataReader dr = cmd.ExecuteReader();
while (dr.Read())
{
stuXH.Items.Add(dr[0]);
}
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=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.Tables[0].DefaultView;
}
finally
{
conn.Close();
}
}
StuZY(ComboBox1)事件的代码如下:
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 = new SqlCommand(_sql, conn);
try
{
conn.Open();
SqlDataReader dr = cmd.ExecuteReader();
while (dr.Read())
{
stuXH.Items.Add(dr[0]);
}
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=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.Tables[0].DefaultView;
}
finally
{
conn.Close();
}
}
StuXH(ComboBox2)事件的代码如下:
private void stuXH_SelectedIndexChanged(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 XS_KC.XH='"+stuXH.Text+"'and XS_KC.XH=XS.XH and XS_KC.KCH=KC.KCH";
if (stuKCM.Text.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.Tables[0].DefaultView;
}
StuKCM(ComboBox3)事件的代码如下:
private void stuKCM_SelectedIndexChanged(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
展开阅读全文