C实习报告学生成绩管理系统.doc
《C实习报告学生成绩管理系统.doc》由会员分享,可在线阅读,更多相关《C实习报告学生成绩管理系统.doc(18页珍藏版)》请在咨信网上搜索。
重 庆 工 程 职 业 技 术 学 院 《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- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 实习 报告 学生 成绩管理系统
咨信网温馨提示:
1、咨信平台为文档C2C交易模式,即用户上传的文档直接被用户下载,收益归上传人(含作者)所有;本站仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。所展示的作品文档包括内容和图片全部来源于网络用户和作者上传投稿,我们不确定上传用户享有完全著作权,根据《信息网络传播权保护条例》,如果侵犯了您的版权、权益或隐私,请联系我们,核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
2、文档的总页数、文档格式和文档大小以系统显示为准(内容中显示的页数不一定正确),网站客服只以系统显示的页数、文件格式、文档大小作为仲裁依据,个别因单元格分列造成显示页码不一将协商解决,平台无法对文档的真实性、完整性、权威性、准确性、专业性及其观点立场做任何保证或承诺,下载前须认真查看,确认无误后再购买,务必慎重购买;若有违法违纪将进行移交司法处理,若涉侵权平台将进行基本处罚并下架。
3、本站所有内容均由用户上传,付费前请自行鉴别,如您付费,意味着您已接受本站规则且自行承担风险,本站不进行额外附加服务,虚拟产品一经售出概不退款(未进行购买下载可退充值款),文档一经付费(服务费)、不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
4、如你看到网页展示的文档有www.zixin.com.cn水印,是因预览和防盗链等技术需要对页面进行转换压缩成图而已,我们并不对上传的文档进行任何编辑或修改,文档下载后都不会有水印标识(原文档上传前个别存留的除外),下载后原文更清晰;试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓;PPT和DOC文档可被视为“模板”,允许上传人保留章节、目录结构的情况下删减部份的内容;PDF文档不管是原文档转换或图片扫描而得,本站不作要求视为允许,下载前自行私信或留言给上传者【精***】。
5、本文档所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用;网站提供的党政主题相关内容(国旗、国徽、党徽--等)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。
6、文档遇到问题,请及时私信或留言给本站上传会员【精***】,需本站解决可联系【 微信客服】、【 QQ客服】,若有其他问题请点击或扫码反馈【 服务填表】;文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“【 版权申诉】”(推荐),意见反馈和侵权处理邮箱:1219186828@qq.com;也可以拔打客服电话:4008-655-100;投诉/维权电话:4009-655-100。
1、咨信平台为文档C2C交易模式,即用户上传的文档直接被用户下载,收益归上传人(含作者)所有;本站仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。所展示的作品文档包括内容和图片全部来源于网络用户和作者上传投稿,我们不确定上传用户享有完全著作权,根据《信息网络传播权保护条例》,如果侵犯了您的版权、权益或隐私,请联系我们,核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
2、文档的总页数、文档格式和文档大小以系统显示为准(内容中显示的页数不一定正确),网站客服只以系统显示的页数、文件格式、文档大小作为仲裁依据,个别因单元格分列造成显示页码不一将协商解决,平台无法对文档的真实性、完整性、权威性、准确性、专业性及其观点立场做任何保证或承诺,下载前须认真查看,确认无误后再购买,务必慎重购买;若有违法违纪将进行移交司法处理,若涉侵权平台将进行基本处罚并下架。
3、本站所有内容均由用户上传,付费前请自行鉴别,如您付费,意味着您已接受本站规则且自行承担风险,本站不进行额外附加服务,虚拟产品一经售出概不退款(未进行购买下载可退充值款),文档一经付费(服务费)、不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
4、如你看到网页展示的文档有www.zixin.com.cn水印,是因预览和防盗链等技术需要对页面进行转换压缩成图而已,我们并不对上传的文档进行任何编辑或修改,文档下载后都不会有水印标识(原文档上传前个别存留的除外),下载后原文更清晰;试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓;PPT和DOC文档可被视为“模板”,允许上传人保留章节、目录结构的情况下删减部份的内容;PDF文档不管是原文档转换或图片扫描而得,本站不作要求视为允许,下载前自行私信或留言给上传者【精***】。
5、本文档所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用;网站提供的党政主题相关内容(国旗、国徽、党徽--等)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。
6、文档遇到问题,请及时私信或留言给本站上传会员【精***】,需本站解决可联系【 微信客服】、【 QQ客服】,若有其他问题请点击或扫码反馈【 服务填表】;文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“【 版权申诉】”(推荐),意见反馈和侵权处理邮箱:1219186828@qq.com;也可以拔打客服电话:4008-655-100;投诉/维权电话:4009-655-100。
关于本文