1、数据库系统应用课程设计课程设计汇报 设 计 题 目: 学生成绩管理系统_ 专 业 (方 向): 信息管理和信息系统 年 级、 班: xxxxxxxxx 学 生 学 号: xxxxxxxxxx 学 生 姓 名: XX 指 导 教 师: XXX 12 月 17 日目 录一、概述5(一)、设计目标5(二)、开发工具选择5二、需求分析5(一)、功效需求分析5(二)、性能需求分析6三、总体设计6(一)、系统总体结构及功效模块划分61、系统管理模块62、学生信息管理模块73、班级信息管理模块74、课程信息管理模块75、成绩信息管理模块8(二)、系统数据库概念结构设计81、学生信息表8四、具体设计9(一)、
2、系统管理功效模块实现9(二)、学生信息管理模块实现11(三)、班级信息管理模块实现14(四)、课程信息管理模块实现16(五)、成绩信息管理模块实现19五、系统测试和运行21六、结束语24摘 要本文描述是基于Windows环境学生管理系统,关键功效模块包含学生信息添加、修改、查找、删除。关键工具Microsoft Visual Studio设计窗体,SQL server建立数据库,实现学生信息管理基础功效。本篇汇报介绍一个学生信息管理系统从分析到设计最终到实现全过程,给出了学生信息管理系统设计和技术实现过程,尤其在细节上分析功效和函数实现思想。包含到雪上信息管理基础功效在本汇报中全部有描述。Ab
3、stractDescribed 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 Studio SQL Server design form, database, information management students to achiev
4、e 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 o
5、f the realization of ideas. Relate to the snow on the basic functions of information management in this report are described.关键词 数据库,添加,修改,查找,删除学生信息管理系统一、概述本文描述是基于Windows环境学生管理系统,关键功效模块包含学生信息添加、修改、查找、删除。关键工具Microsoft Visual Studio设计窗体,SQL server建立数据库,实现学生信息管理基础功效。(一)、设计目标本课程设计目标是使学生能熟练掌握简单Window窗体应用
6、程序设计和ADD.net应用,期望经过此次锻炼学生实用c#语言处理实际问题能力。(二)、开发工具选择Microsoft Visual Studio(简称VS)是美国微软企业开发工具包系列产品。VS是一个基础完整开发工具集,它包含了整个软件生命周期中所需要大部分工具,如UML工具、代码管控工具、集成开发环境(IDE)等等。所写目标代码适适用于微软支持全部平台,包含Microsoft Windows、Windows Mobile、Window CE、.NET Framework、.NET Compact Framework和Microsoft Silver light及Windows Phone。
7、Visual Studio是现在最流行Windows平台应用程序集成开发环境。最新版本为VisualStudio本,基于.NETFramework4.5.2。二、需求分析(一)、功效需求分析本系统功效需求分析以下:系统用户:用户,密码,退出。学生基础信息:学号 ,姓名,性别, 电话,班号,生日,住址。班级信息:班号,年级,班主任。课程基础信息:课程号,课程名,课程类别,学分。学生成绩信息:学号,班号,课程类型,学分。(二)、性能需求分析(1) 登录、用户界面需求: 简练、易懂、易用、有好用户界面(2) 安全保密需求: 只有凭借用户名和密码登录系统,才能进行信息管理。三、总体设计(一)、系统总体
8、结构及功效模块划分经过对系统需求分析,学生信息管理系统关键划分为:系统管理,学生信息管理,班级信息管理,课程信息管理,学籍信息管理,成绩信息管理六个模块,图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、课程信息管理模块课程信息管理:添加课程信息,
9、修改课程信息,设置课程信息,图3.1.4所表示。图3.1.4课程信息管理模块结构5、成绩信息管理模块成绩信息管理:添加成绩信息,修改成绩信息,查询成绩信息,图3.1.5所表示。图3.1.5成绩信息管理模块结构(二)、系统数据库概念结构设计信息表设计:1、学生信息表如Error! Reference source not found.所表示。表 1学生信息表列名数据类型长度备注学号Char8主键姓名string20无性别Enumeration1无生日Datatime10无照片Byte50无联络电话Varchar20无地址string20无3.2.2班级信息表如Error! Reference s
10、ource not found.所表示。表 2班级信息表列名数据类型长度备注班号char5主键班级名称String10无班主任String 5无3.2.3课程信息表如Error! Reference source not found.所表示。表 3课程信息表列名数据类型长度备注课程号Char5主键课程名称String 10无课程类型string5无学分int5无3.2.4成绩信息表如Error! Reference source not found.所表示。表 4成绩信息表列名数据类型长度备注学号Char10主键课程号Char5主键成绩类型String5无分数float5无3.2.5用户信息表
11、如Error! Reference source not found.所表示。表 5用户信息表列名数据类型长度备注登录IDchar5主键登录名String10无用户名String 10无密码String 10四、具体设计(一)、系统管理功效模块实现创建一个FormSystemMessage窗体,实现添加用户、删除用户、修改密码、退出系统功效。public partial class FormSystemMessage : Form public FormSystemMessage() InitializeComponent(); private void operatorBindingNavi
12、gatorSaveItem_Click(object sender, EventArgs e) this.Validate(); this.operatorBindingSource.EndEdit(); this.tableAdapterManager.UpdateAll(this.dataSetUserPassword); DataSetUserPassword dsp = new DataSetUserPassword(); DataSetUserPasswordTableAdapters.OperatorTableAdapter dsup = new DataSetUserPasswo
13、rdTableAdapters.OperatorTableAdapter(); private void FormSystemMessage_Load(object sender, EventArgs e) / TODO: 这行代码将数据加载到表“dataSetUserPassword.Operator”中。您能够根 据需要移动或删除它。 this.operatorTableAdapter.Fill(this.dataSetUserPassword.Operator); dsup.Fill(dsp.Operator); dataGridViewSystemMessage.DataSource
14、= 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();
15、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.Er
16、ror); 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) try dsup.Update(dsp.Operator); MessageBox.Show(数据保留成功, 提醒信息
17、, 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“学生信息管理”窗体在结构函数前添加数据
18、库上下文对象,并在结构函数中增加以下代码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(); co
19、urse.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 (stud
20、entBindingSource.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 = studentBindin
21、gSource.Current as Student; FormStudentEdit formEdit = new FormStudentEdit(student); if(formEdit .ShowDialog ()=DialogResult.OK) studentBindingSource.EndEdit(); db.SaveChanges(); else db.Entry(student).Reload(); studentBindingSource.ResetBindings(false ); 4.2.2.“编辑学生信息”窗体设计图4.2.2所表示。图 4.2.2“编辑学生信息”窗
22、体设计在该窗体中“选择照片”按钮代码实现以下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(op
23、enDialog.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“班级
24、信息管理”窗体设计在结构函数前添加数据库上下文对象,并在结构函数中增加以下代码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 C
25、lass(); 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 (c
26、lassBindingSource.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; F
27、ormEditClass formEdit = new FormEditClass( ); if (formEdit.ShowDialog() = DialogResult.OK) db.SaveChanges(); else db.Entry(classes ).Reload(); 4.3.2.“编辑班级信息”窗体图4.3.2所表示。图4.3.2“编辑班级信息”窗体设计“确定”按钮代码实现以下private void buttonOK_Click(object sender, EventArgs e) if (ValidateData() DialogResult = DialogResul
28、t.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.Loa
29、d(); 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) co
30、urseBindingSource.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(删除成功); “编辑”
31、按钮实现代码以下 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(); else
32、db.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;
33、 (五)、成绩信息管理模块实现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_Cli
34、ck(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(); “删除”按
35、钮实现代码以下 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 (scoreBind
36、ingSource.Current = null) return; Score score = scoreBindingSource.Current as Score; FormEditScore formEdit = new FormEditScore(); if (formEdit.ShowDialog() = DialogResult.OK) scoreBindingSource.EndEdit(); db.SaveChanges(); else db.Entry(score).Reload(); scoreBindingSource.ResetBindings(false); 4.5.2.“成绩信息编辑”窗体设计图4.5.2所表示。图 4