




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
XXXXXX学院C#课程考查工程题目:学生成绩信息管理系统专业班级:学生姓名:XX年XX月XX日目录摘要 1第一章绪论 21.1设计目的 21.2开发工具选择 21.3开发环境 21.4本报告的主要内容 2第二章需求分析 32.1系统需求简介 3系统目标 3功能需求分析 3性能需求分析 3第三章总体设计 43.1设计概述 43.2系统总体结构及功能模块划分 4学生信息查询模块 4学生信息管理模块 53.3系统数据库概念结构设计 5系统E-R图 5系统数据库的设计 63.4平安保密设计 7用户登录平安性 7第四章详细设计 84.1概述 84.2系统程序流程图 84.3系统主要功能模块简介 9系统登录 9学生信息查询模块 9学生信息管理模块 10音乐播放器 12第五章主要功能模块代码 155.1公共类代码设计 155.2登录界面代码设计 165.3查询模块代码设计 175.4添加模块代码设计 185.5更新模块代码设计 195.6删除模块代码设计 195.7图片显示代码设计 195.8播放器翻开代码设计 20第六章课程设计心得 22C#学生成绩管理系统摘要本文描述的是基于Windows环境的学生信息管理系统,主要功能模块包括:学生信查询,学生信息管理,学生成绩录入,主要工具MicrosoftVisualStudio2021设计窗体,SQLserver2021建立数据库,实现学校信息管理的各个功能。本篇报告介绍一个学生信息管理系统的从分析到设计最后到开发的全过程为,给出了学生信息管理系统的设计和技术实现的过程,特别在细节上分析功能和函数的实现思想。涉及到学生信息管理的根本功能在本报告中都有相应的描述。
1.1设计目的本课程设计的目的是使学生能熟练掌握简单的简单Windows窗体应用程序的设计和ADO.net的应用,希望通过本次课程设计锻炼学生使用C#语言解决实际问题的能力。1.2开发工具选择本系统后台数据库采用MicrosoftSQLServer数据库,该数据库系统在平安性、准确性和运行速度方面有绝对的优势,并且处理数据量大,效率高;前台采用Microsoft公司的VisualStudio2021作为主要开发工具,可与SQLServer2021数据库无缝链接。1.3开发环境系统开发平台:MicrosoftVisualStudio2021系统开发语言:C#数据库管理软件:SQLServer20211.4本报告的主要内容本报告详细的介绍了学生信息管理系统的开发过程,主要涉及到的工作如下:系统的需求分析、系统的总体设计、系统的概念设计、系统各模块的详细设计、系统运行与测试。
2.1系统需求简介根据查询条件实现学生信息的查询学生选课信息查询、成绩信息的查询学生信息、课程信息、成绩信息的增加、删除、修改对根本信息完成增加、删除、修改时,需注意表与表之间的关联本系统的功能需求分析如下:学生信息查询:学生可以根据学号、姓名、专业进行查询.学生信息管理:主要是用于学生信息更新、插入、删除;学生成绩录入:用于学生成绩管理,录入学生成绩,也可以更新;登录、用户界面需求:简洁、易懂、易用、友好的用户界面。平安保密性需求:只有凭借用户名和密码登陆系统,才能进行信息的管理等。
3.1设计概述根据需求把整个系统分化成不同的模块,每个模块完成一个特定的子功能。把这些模块结合起来组成一个整体。逐一实现各个功能;3.2系统总体结构及功能模块划分学生成绩录入学生信息管理学生信息管理系统学生信息查询经过对系统的需求分析,学生信息管理系统主要划分为三个局部:学生成绩录入学生信息管理学生信息管理系统学生信息查询学生信息查询性别查询姓名查询学生信息查询:学生可以根据姓名、性别进行查询。如图3.2.2学生学生信息查询性别查询姓名查询根本信息录入成绩录入根本信息更新成绩更新学生信息删除学生信根本信息录入成绩录入根本信息更新成绩更新学生信息删除学生信息录入学生信息管理学生信息更新3.3系统数据库概念结构设计根据对数据项与数据结构的分析,设计出能够满足系统需求的各种实体,及它们之间的关系,为后面的逻辑结构设计打下根底。系统E-R图可以将各个实体之间的关系显示出来,将各个实体间的属性依赖表示明白。如图3.3.1系统E-R图结构姓名姓名语文语文学号学号 数学学生表数学学生表成绩成绩英语性别英语性别综合以上分析,要实现上面的所有功能模块,主要设计表如下:3.4平安保密设计系统设计了登录界面,每个合法用户有用户名及一个密码,只有当用户输入正确的用户名及密码组合后才能够对学生信息进行操作。
4.1概述详细设计阶段的根本目标是确定应该怎样具体的实现所要求的系统,也就是说,经过这个阶段的设计工作,应该得出目标系统的精确描述,从而在编码阶段可以把这个描述直接翻译成用某种程序设计语言书写的程序。4.2系统程序流程图程序流程图又称为程序框图,它是历史悠久使用最广泛的描述软件设计的方法。它可将整个程序的总体流程清楚明白的显示出来。如图系统主要功能模块简介用户凭借用户名及密码登录,成功登录后可对学生信息进行操作。用户界面如图用户登录界面所示。学生信息查询:在程序主界面〔如图程序主界面〕学生可以根据学号、姓名进行查询。学生也可以只用一种条件进行信息查询,也可以多个条件查询。单击记录任一单元格可显示学生的更详细信息〔如图4.3.3详细信息窗口〕。学生信息管理:通过右击程序主界面的相应记录弹出的上下文菜单〔如图上下文菜单〕可对当前选定学生信息进行详细信息查询〔如图4.3.3详细信息窗口〕、修改信息〔如图4.3.5修改信息窗口〕、删除信息〔如图4.3.6删除信息提示〕。更新时如果输入的学号不存在,可选择是否添加学生信息。通过程序主界面的新建信息记录可添加学生信息〔如图4.3.7添加信息窗口〕、条件筛选(如图4.3.8),可按性别查询和学生姓名查询。图修改信息窗口音乐播放:当用户登录成功,进入主窗口之后,会很明显的看到一个播放器,如下图,在播放器的下面有三个按钮,可以实现翻开(图4.3.10),播放/暂停,和默认音乐.图图歌词流动显示:进入主界面后可以看到右边有一块区域(图4.3.11),这里便是显示歌词的.图1图2
5.1公共类代码设计namespaceMyHelper{classSqlHelper{publicstaticreadonlystringconnstr=ConfigurationManager.ConnectionStrings["dbconnstr"].ConnectionString;publicstaticintExecuteNonQuery(stringcmdText,paramsSqlParameter[]parameters){using(SqlConnectionconn=newSqlConnection(connstr)){conn.Open();using(SqlCommandcmd=conn.CreateCommand()){cmd.CommandText=cmdText;cmd.Parameters.AddRange(parameters);returncmd.ExecuteNonQuery();}}}publicstaticobjectExecuteScalar(stringcmdText,paramsSqlParameter[]parameters){using(SqlConnectionconn=newSqlConnection(connstr)){conn.Open();using(SqlCommandcmd=conn.CreateCommand()){cmd.CommandText=cmdText;cmd.Parameters.AddRange(parameters);returncmd.ExecuteScalar();}}}publicstaticDataTableExecuteDataTable(stringcmdText,paramsSqlParameter[]parameters){using(SqlConnectionconn=newSqlConnection(connstr)){conn.Open();using(SqlCommandcmd=conn.CreateCommand()){cmd.CommandText=cmdText;cmd.Parameters.AddRange(parameters);using(SqlDataAdapteradapter=newSqlDataAdapter(cmd)){DataTabledt=newDataTable();adapter.Fill(dt);returndt;}}}}publicstaticSqlDataReaderExecuteDataReader(stringcmdText,paramsSqlParameter[]parameters){SqlConnectionconn=newSqlConnection(connstr);conn.Open();using(SqlCommandcmd=conn.CreateCommand()){cmd.CommandText=cmdText;cmd.Parameters.AddRange(parameters);returncmd.ExecuteReader(CommandBehavior.CloseConnection);}}}}5.2登录界面代码设计privatevoidlogin_Click(objectsender,EventArgse){//用户名及密码组合判断if(username.Text.ToString().Trim()!=""&&password.Text.ToString().Trim()!=""){if(txtUserName.Text=="Ewi"||txtUserName.Text=="强强"){if(txtPsw.Text=="111"){MessageBox.Show("登录成功!","提示?",MessageBoxButtons.OK,MessageBoxIcon.Information);DialogResult=DialogResult.OK;}else{MessageBox.Show("密码错误,您还有"+i+"次时机...");i--;}}else{MessageBox.Show("亲,没有此用户名");}}5.3查询模块代码设计QueryFrmquery=newQueryFrm();if(query.ShowDialog()==DialogResult.OK){DataTabledt=SqlHelper.ExecuteDataTable("selectidas'编号',Nameas'姓名',Sexas'性别',Englishas'英语',Chineseas'语文',Mathas'数学'fromT_Studentwherename=@name",newSqlParameter("@name",query.Name));if(dt.Rows.Count>=1){dataGridView1.DataSource=dt;}else{MessageBox.Show("没有找到您所查询的结果,请重新查询","提示",MessageBoxButtons.OK,MessageBoxIcon.Information);}}5.4添加模块代码设计if(txtName.Text.Trim()==""||txtChi.Text.Trim()==""||txtEng.Text.Trim()==""||txtMath.Text.Trim()==""){MessageBox.Show("请将信息填写完整","警告?",MessageBoxButtons.OK,MessageBoxIcon.Information);return;}else{if(rbMale.Checked){SqlHelper.ExecuteNonQuery("insertintoT_Student(name,sex,english,math,chinese)values(@name,@sex,@Eng,@Math,@Chi)",newSqlParameter("@name",txtName.Text),newSqlParameter("@Eng",Convert.ToInt32(txtEng.Text)),newSqlParameter("@sex","男D"),newSqlParameter("@Chi",Convert.ToInt32(txtChi.Text)),newSqlParameter("@Math",Convert.ToInt32(txtMath.Text)));}else{SqlHelper.ExecuteNonQuery("insertintoT_Student(name,sex,english,math,chinese)values(@name,@sex,@Eng,@Math,@Chi)",newSqlParameter("@name",txtName.Text),newSqlParameter("@Eng",txtEng.Text),newSqlParameter("@sex","女?"),newSqlParameter("@Chi",txtChi.Text),newSqlParameter("@Math",txtMath.Text));}MessageBox.Show("添加成功?");DialogResult=DialogResult.OK;this.Close();5.5更新模块代码设计voidLoadDataGradView(){DataTabledt=SqlHelper.ExecuteDataTable("selectidas'编号',Nameas'姓名',Sexas'性别',Englishas'英语',Chineseas'语文',Mathas'数学'fromT_Student");dataGridView1.DataSource=dt;dataGridView1.SelectionMode=DataGridViewSelectionMode.FullRowSelect;}5.6删除模块代码设计DialogResultdrCurr=MessageBox.Show("确定删除?","提示?...",MessageBoxButtons.OKCancel,MessageBoxIcon.Question);if(DialogResult.OK==drCurr){SqlHelper.ExecuteNonQuery("deleteT_Studentwhereid=@id",newSqlParameter("@id",selectId));LoadDataGradView();}5.7图片显示代码设计voidGet_Img(intid){byte[]imagebytes=null;SqlDataReaderdr=SqlHelper.ExecuteDataReader("select*fromT_Studentwhereid="+id);while(dr.Read()){try{imagebytes=(byte[])dr.GetValue(6);MemoryStreamms=newMemoryStream(imagebytes);Bitmapbmpt=newBitmap(ms);}catch(Exception){stringstrImgFile=Application.StartupPath;strImgFile=strImgFile.Substring(0,strImgFile.LastIndexOf("\\"));strImgFile=strImgFile.Substr
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 推土机租赁合同书
- 建筑工程合同协议书
- 北京存量房买卖合同
- 总代理合作合同书
- 消防施工施工方案
- 天津改性砂浆施工方案
- TCSHB 0017-2024 生成式人工智能模型训练合规技术规范
- 足球场地基板施工方案
- 黑龙江草莓大棚施工方案
- 桥梁直角垫板施工方案
- 车库租赁合同
- 《工程项目审计》课件
- 法人不参与经营免责协议
- 小学生心理健康主题家长会
- QB/T 4031-2024 阻燃性汽车空气滤纸(正式版)
- DZ∕T 0130-2006 地质矿产实验室测试质量管理规范(正式版)
- 《“光盘”行动-从我做起!》课件
- 杠杆原理及其应用实验报告总结
- 2024年高职考试-渤海船舶职业学院单招笔试参考题库含答案
- 人教新课标高一数学必修一讲义(上半册)共7讲(无答案)
- 低压断路器课件
评论
0/150
提交评论