学生管理信息系统课程设计报告_第1页
学生管理信息系统课程设计报告_第2页
学生管理信息系统课程设计报告_第3页
学生管理信息系统课程设计报告_第4页
学生管理信息系统课程设计报告_第5页
免费预览已结束,剩余31页可下载查看

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

数据库系统应用课程设计课程设计报告设计题目:学生成绩管理系统 专业(方向):信息管理与信息系统年级、班:xxxxxxxxx学生学号:xxxxxxxxxx学生姓名:xx指导教师:xxx2017年 12月 17日精品资料目录一、概述 .7(一)、设计目的 .7(二)、开发工具的选择 .7二、需求分析 .8(一)、功能需求的分析 .8(二)、性能需求分析.8三、总体设计 .8(一)、系统总体结构及功能模块划分.81 、系统管理模块.92 、学生信息管理模块.103 、班级信息管理模块.104 、课程信息管理模块.105 、成绩信息管理模块.11(二)、系统数据库概念结构设计.111 、学生信息表 .11四、详细设计 .13(一)、系统管理功能模块的实现.13(二)、学生信息管理模块的实现.16(三)、班级信息管理模块的实现.20(四)、课程信息管理模块的实现.24(五)、成绩信息管理模块的实现.28五、系统测试与运行.32六、结束语 .34摘要本文描述的是基于windows环境的学生管理系统,主要功能模块包括学生信息的添加、 修改、查找、删除。主要工具microsoft visual studio2010设计窗体, sql server2008建立数据库,实现学生信息管理的基本功能。本篇报告介绍一个学生信息管理系统的从分析到设计最后到实现的全过程,给出了学生信息管理系统的设计和技术实现的过程,特别在细节上分析功能和函数的实现思想。涉及到雪上信息管理的基本功能在本报告中都有描述。abstractdescribed in this paper is based on the windows environment management system for students, the main function modules include student information to add, modify, delete, search. the main tool of microsoft visual studio2010 sql server2008 design form, database, information management students to achieve the basic function.this report describes a student information management system from analysis to design to the final realization of the entire process, gives the student information management system design and realization process, especially in the details of analysis function and the function of the realization of ideas. relate to the snow on the basic functions of information management in this report are described.关键词数据库,添加,修改,查找,删除学生信息管理系统一、概述本文描述的是基于windows环境的学生管理系统,主要功能模块包括学生信息的添加、 修改、查找、删除。主要工具microsoft visual studio2010设计窗体, sql server2008建立数据库,实现学生信息管理的基本功能。(一)、设计目的本课程设计的目的是使学生能熟练掌握简单的window 窗体应用程序的设计和add.net的应用,希望通过本次的锻炼学生实用c# 语言解决实际问题的能力。(二)、开发工具的选择microsoft visual studio(简称 vs )是美国微软公司的开发工具包系列产品。vs 是一个基本完整的开发工具集,它包括了整个软件生命周期中所需要的大部分工具,如uml 工具、代码管控工具、集成开发环境(ide) 等等。所写的目标代码适用于微软支持的所有平台,包括microsoftwindows 、windowsmobile 、windowce 、.netframework 、.netcompact framework和 microsoftsilverlight及 windowsphone 。visualstudio是目前最流行的windows平台 应用 程序的集 成开 发 环境 。 最 新版 本为visualstudio2015版 本, 基于.netframework4.5.2。精品资料二、需求分析(一)、功能需求的分析本系统的功能需求分析如下: 系统用户:用户,密码,退出。学生基本信息:学号,姓名,性别,电话,班号,生日,住址。班级信息:班号,年级,班主任。课程基本信息:课程号,课程名,课程类别,学分。学生成绩信息:学号,班号,课程类型,学分。(二)、性能需求分析(1) ) 登录、用户界面需求:简洁、易懂、易用、有好的用户界面(2) ) 安全保密需求:只有凭借用户名和密码登录系统,才能进行信息的管理。三、 总体设计(一)、系统总体结构及功能模块划分经过对系统的需求分析,学生信息管理系统主要划分为:系统管理,学生信息管理,班级信息管理,课程信息管理,学籍信息管理,成绩信息管理六个模块,如图3.1 所示。图 3.1 系统的总体结构1 、系统管理模块系统用户 : 这里面包含添加用户 ,修改密码 ,退出系统三个小部分,如图3.1.1 所示。图 3.1.1 系统用户模块结构2 、学生信息管理模块学生信息管理:主要是用于学生信息更新、插入、删除,如图3.1.2 所示。图 3.1.2 学生信息管理模块结构3 、班级信息管理模块班级信息管理:添加班级信息,修改班级信息,如图3.1.3 所示。图 3.1.3 班级信息管理模块结构4 、课程信息管理模块课程信息管理:添加课程信息,修改课程信息 ,设置课程信息,如图3.1.4 所示。图 3.1.4 课程信息管理模块结构5 、成绩信息管理模块成绩信息管理:添加成绩信息,修改成绩信息,查询成绩信息,如图3.1.5 所示。图 3.1.5 成绩信息管理模块结构(二)、系统数据库概念结构设计信息表设计:1 、学生信息表如表 2 所示。表1 学生信息表列名数据类型长度备注学号char8主键姓名string20无性别enumeration1无生日datatime10无照片byte50无联系电话varchar20无地址string20无3.2.2 班级信息表如 错误!未找到引用源。所示。表2 班级信息表列名数据类型长度备注班号char5主键班级名称string10无班主任string5无3.2.3 课程信息表如 错误!未找到引用源。所示。表3 课程信息表列名数据类型长度备注课程号char5主键课程名称string10无课程类型string5无学分int5无3.2.4 成绩信息表如表 4 所示。表4 成绩信息表列名学号数据类型char长度10备注主键课程号char5主键成绩类型string5无分数float5无3.2.5 用户信息表如表5 所示。表5 用户信息表列名数据类型长度备注登录 idchar5主键登录名string10无用户名string10无密码string10四、详细设计(一)、系统管理功能模块的实现创建一个 formsystemmessage窗体,实现添加用户、删除用户、修改密码、退出系统的功能。public partial class formsystemmessage : formpublic formsystemmessage()initializecomponent();private void operatorbindingnavigatorsaveitem_click(object sender, eventargs e)this.validate();this.operatorbindingsource.endedit();this.tableadaptermanager.updateall(this.datasetuserpassword);datasetuserpassword dsp = new datasetuserpassword();datasetuserpasswordtableadapters.operatortableadapter dsup =new datasetuserpasswordtableadapters.operatortableadapter();private void formsystemmessage_load(object sender, eventargs e)/ todo:这行代码将数据加载到表“ datasetuserpassword.operator”中。您可以根 据需要移动或删除它。this.operatortableadapter.fill(this.datasetuserpassword.operator);dsup.fill(dsp.operator);datagridviewsystemmessage.datasource = dsp.operator;private void buttondelete_click(object sender, eventargs e)datasetuserpassword.operatorrow row = (datasetuserpassword.operatorrow)(datarowview)datagridviewsystemmessage.currentrow.databounditem).row);if (messagebox.show(您确定要删除这个用户吗?, 确定提示 ) = dialogresult.no) return;row.delete();private void buttonadd_click(object sender, eventargs e)if (string.isnullorempty(nametextbox.text)messagebox.show(用户名不能为空 , 错误提示 , messageboxbuttons.ok,messageboxicon.error);return;if (string.isnullorempty(passwordtextbox.text)messagebox.show(密码不能为空 , 错误提示 , messageboxbuttons.ok,messageboxicon.error);return;datasetuserpassword.operatorrow row = dsp.operator.newoperatorrow();row.name = nametextbox.text;row.password = passwordtextbox.text;dsp.operator.addoperatorrow(row);private void buttonsave_click(object sender, eventargs e)trydsup.update(dsp.operator);messagebox.show(数据保存成功 , 提示信息 , messageboxbuttons.ok,messageboxicon.information);catch (exception ex)messagebox.show(ex.message, 提示信息 , messageboxbuttons.ok, messageboxicon.error);private void buttonexit_click(object sender, eventargs e)application.exit();(二)、学生信息管理模块的实现4.2.1. “学生信息管理”窗体的实现如图4.2.1 所示。图 4.2.1 “学生信息管理”窗体在构造函数前添加数据库上下文对象,并在构造函数中增加以下代码scoremancontext db = new scoremancontext();public formclass()initializecomponent();db.studentes.load();studentbindingsource.datasource = db.studentes.local;“新添”按钮代码实现如下private void bindingnavigatoraddnewitem_click(object sender, eventargs e)student student = new course();course.id = guid.newguid();formeditcourse formedit = new formeditcourse(course );if(formedit.showdialog ()=dialogresult.ok)coursebindingsource.add(course);coursebindingsource.endedit();db.savechanges();“删除”按钮代码实现如下private void bindingnavigatordeleteitem_click(object sender, eventargs e)if (studentbindingsource.current = null) return;if(dialogs.showconfirm (你确定删除吗 )=dialogresult.yes)studentbindingsource.removecurrent();db.savechanges();“编辑”按钮代码实现如下private void toolstripedit_click(object sender, eventargs e)if (studentbindingsource.current = null) return;student student = studentbindingsource.current as student;formstudentedit formedit = new formstudentedit(student);if(formedit .showdialog ()=dialogresult.ok)studentbindingsource.endedit();db.savechanges();elsedb.entry(student).reload();studentbindingsource.resetbindings(false );4.2.2. “编辑学生信息”窗体设计如图4.2.2 所示。图 4.2.2 “编辑学生信息”窗体设计在该窗体中“选择照片”按钮代码实现如下private void buttonselectpicture_click(object sender, eventargs e)openfiledialog opendialog = new openfiledialog();opendialog.filter = 所有图片( *.jpg;*.png;*.bmp;*.gif) |*.jpg;*.png;*.gif;*.bmp; if(opendialog .showdialog()=dialogresult.ok)photopicturebox.image = image.fromfile(opendialog.filename);“确定”按钮代码实现如下private void buttonok_click(object sender, eventargs e)if (validatedata()dialogresult = dialogresult.ok;“取消”按钮代码实现如下private void buttoncancel_click(object sender, eventargs e)dialogresult = dialogresult.cancel;(三)、班级信息管理模块的实现4.3.1. “班级信息管理”窗体设计如图4.3.1 所示。图 4.3.1 “班级信息管理”窗体设计在构造函数前添加数据库上下文对象,并在构造函数中增加以下代码scoremancontext db = new scoremancontext();public formclass()initializecomponent();db.classes.load();classbindingsource.datasource = db.classes.local;“新添”按钮代码实现如下private void bindingnavigatoraddnewitem_click(object sender, eventargs e)class classes = new class();classes.id = guid.newguid();formeditclass formedit = new formeditclass();if (formedit.showdialog() = dialogresult.ok)classbindingsource.add(classes);classbindingsource.endedit();db.savechanges();“删除”按钮代码实现如下private void bindingnavigatordeleteitem_click(object sender, eventargs e)if (classbindingsource.current = null)return;classbindingsource.removecurrent();db.savechanges();dialogs.showmessage(删除成功 );“编辑”按钮代码实现如下private void toolstripbutton1_click(object sender, eventargs e)if (classbindingsource.current = null)return;class classes = classbindingsource.current as class;formeditclass formedit = new formeditclass( );if (formedit.showdialog() = dialogresult.ok)db.savechanges();elsedb.entry(classes ).reload();4.3.2. “编辑班级信息”窗体如图4.3.2 所示。图 4.3.2 “编辑班级信息”窗体设计“确定”按钮代码实现如下private void buttonok_click(object sender, eventargs e)if (validatedata()dialogresult = dialogresult.ok;“取消”按钮代码实现如下private void buttoncancel_click(object sender, eventargs e)dialogresult = dialogresult.cancel;(四)、课程信息管理模块的实现4.4.1. “课程信息窗体”设计如图4.4.1 所示。图 4.4.1 “课程信息窗体”设计在构造函数前添加数据库上下文对象,并在构造函数中增加以下代码scoremancontext db = new scoremancontext(); public formclass()initializecomponent(); db.courses.load();coursebindingsource.datasource = db.courses.local;“新添”按钮实现代码如下private void bindingnavigatoraddnewitem_click(object sender, eventargs e)course course = new course(); course.id = guid.newguid();formeditcourse formedit = new formeditcourse(course ); if(formedit.showdialog ()=dialogresult.ok)coursebindingsource.add(course); coursebindingsource.endedit(); db.savechanges();“删除”按钮实现代码如下private void bindingnavigatordeleteitem_click(object sender, eventargs e)if (coursebindingsource.current = null)return;coursebindingsource.removecurrent();db.savechanges();dialogs.showmessage(删除成功 );“编辑”按钮实现代码如下private void toolstripbuttonedit_click(object sender, eventargs e)if (coursebindingsource.current = null)return;course course = coursebindingsource.current as course;formeditcourse formedit = new formeditcourse(course);if(formedit .showdialog ()=dialogresult.ok)db.savechanges();elsedb.entry(course).reload();4.4.2. “编辑课程信息”窗体设计如图4.4.2 所示。图 4.4.2 “编辑课程信息”窗体设计“确定”按钮代码实现如下private void buttonok_click(object sender, eventargs e)if (validatedata()dialogresult = dialogresult.ok;“取消”按钮代码实现如下private void buttoncancel_click(object sender, eventargs e)dialogresult = dialogresult.cancel;(五)、成绩信息管理模块的实现4.5.1. “成绩信息管理”窗体设计如图4.5.1 所示。图 4.5.1 “成绩信息管理”窗体设计在构造函数前添加数据库上下文对象,并在构造函数中增加以下代码scoremancontext db = new scoremancontext(); public formclass()initializecomponent(); db.scores.load();scorebindingsource.datasource = db.scores.local;“新添”按钮实现代码如下private void bindingnavigatoraddnewitem_click(object sender, eventargs e)score score = new score(); score.studentid = guid.newguid(); score.courseid = guid.newguid();formeditscore formedit = new formeditscore(); if (formedit.showdialog() = dialogresult.ok)scorebindingsource.add(score); scorebindingsource.endedit(); db.savechanges();“删除”按钮实现代码如下private void bindingnavigatordeleteitem_click(object sender, eventargs e)if (scorebindingsource.current = null) return;scorebindingsource.removecurrent(); db.savechanges(); dialogs.showmessage(删除成功 );“编辑”按钮实现代码如下private void toolstripbutton1_click(object sender, eventargs e)if (scorebinding

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论