最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 正文

学生管理信息系统课程设计报告

来源:动视网 责编:小OO 时间:2025-09-23 21:06:33
文档

学生管理信息系统课程设计报告

《数据库系统应用课程设计》课程设计报告设计题目:学生成绩管理系统__专业(方向):信息管理与信息系统年级、班:xxxxxxxxx学生学号:xxxxxxxxxx学生姓名:XX指导教师:XXX2017年12月17日摘要本文描述的是基于Windows环境的学生管理系统,主要功能模块包括学生信息的添加、修改、查找、删除。主要工具MicrosoftVisualStudio2010设计窗体,SQLserver2008建立数据库,实现学生信息管理的基本功能。本篇报告介绍一个学生信息管理系统的从分析到设计最后
推荐度:
导读《数据库系统应用课程设计》课程设计报告设计题目:学生成绩管理系统__专业(方向):信息管理与信息系统年级、班:xxxxxxxxx学生学号:xxxxxxxxxx学生姓名:XX指导教师:XXX2017年12月17日摘要本文描述的是基于Windows环境的学生管理系统,主要功能模块包括学生信息的添加、修改、查找、删除。主要工具MicrosoftVisualStudio2010设计窗体,SQLserver2008建立数据库,实现学生信息管理的基本功能。本篇报告介绍一个学生信息管理系统的从分析到设计最后
《数据库系统应用课程设计》

课程设计报告

 

 

 

 

 

 

 

设   计   题  目:    学生成绩管理系统__  

专   业 (方  向):   信息管理与信息系统   

年     级、   班:        xxxxxxxxx       

学   生   学  号:       xxxxxxxxxx       

学   生   姓  名:            XX          

指   导   教  师:            XXX         

2017年 12 月 17 日

摘  要

本文描述的是基于Windows环境的学生管理系统,主要功能模块包括学生信息的添加、修改、查找、删除。主要工具Microsoft Visual Studio2010设计窗体,SQL server2008建立数据库,实现学生信息管理的基本功能。

本篇报告介绍一个学生信息管理系统的从分析到设计最后到实现的全过程,给出了学生信息管理系统的设计和技术实现的过程,特别在细节上分析功能和函数的实现思想。涉及到雪上信息管理的基本功能在本报告中都有描述。

Abstract

Described 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)等等。所写的目标代码适用于微软支持的所有平台,包括Microsoft Windows、Windows Mobile、Window CE、.NET Framework、.NET Compact Framework和Microsoft Silver light及Windows Phone。Visual Studio是目前最流行的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、学生信息表

如表 1所示。

表 1学生信息表

列名数据类型长度备注
学号Char

8主键
姓名string

20
性别Enumeration

1
生日Datatime10
照片Byte

50
联系电话Varchar

20
地址string20
3.2.2班级信息表如表 2所示。

表 2班级信息表

列名数据类型长度备注
班号char5主键
班级名称String

10
班主任String 

5
3.2.3课程信息表如表 3所示。

表 3课程信息表

列名数据类型长度备注
课程号Char

5主键
课程名称String 

10
课程类型string5
学分int5
3.2.4成绩信息表如表 4所示。

表 4成绩信息表

列名数据类型长度备注
学号Char

10主键
课程号Char

5主键
成绩类型String5
分数float5
3.2.5用户信息表如表 5所示。

表 5用户信息表

列名数据类型长度备注
登录ID

char5主键
登录名String

10
用户名String 

10
密码String 

10
四、详细设计

(一)、系统管理功能模块的实现

创建一个FormSystemMessage窗体,实现添加用户、删除用户、修改密码、退出系统的功能。

public partial class FormSystemMessage : Form

    {

        public 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)

        {

            try

            {

                dsup.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();

            }else

            {

                db.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 = "所有图片()

            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();

            }

            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 = 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();

            }else

            {

                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;

        }

(五)、成绩信息管理模块的实现

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 (scoreBindingSource.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.5.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;

        }

五、系统测试与运行

5.1.1系统管理模块测试如5.1.1和5.1.2所示。

图5.1.1系统管理模块测试1

图5.1.2系统管理模块测试2

5.1.2学生信息管理模块测试如5.1.3所示。

图 5.1.3 学生信息管理模块测试

5.1.3班级信息管理模块测试如5.1.4所示。

图5.1.4班级信息管理模块测试

5.1.4课程信息管理模块测试如图5.1.5所示。

图 5.1.5 课程信息管理模块测试

5.1.5成绩管理模块测试如5.1.6所示。

图5.1.6成绩管理模块测试

六、结束语

在编程期间,不遇到点困难似乎是不可能的,正是这些困难,我们才能会收到成功的喜悦,我们才能乐此不疲的进行下去。这是我对此次编程的最大感悟。

下面来看看编写的艰辛历程:在刚开始的阶段,我经常因为单词的拼错出现这样或那样的错误在数次的错误后我吸取教训在后来的编程中几乎不出现了这种错误。剩下的错误就是引用或语法上的错误。感到最深刻的是,窗体name后就不能随意更改了,更改后在编写的程序的过程中要相应的更新里面的内容。当出现语法错误时我因为经验的不足很难自己将其更改出来,但通过询问老师,在同学的帮助下几乎都能找到我想要的结果。成功后留下的就是经验和成就感了,虽然是一个简单的系统,但是我学到了非常多的知识和积累了很多经验。 

文档

学生管理信息系统课程设计报告

《数据库系统应用课程设计》课程设计报告设计题目:学生成绩管理系统__专业(方向):信息管理与信息系统年级、班:xxxxxxxxx学生学号:xxxxxxxxxx学生姓名:XX指导教师:XXX2017年12月17日摘要本文描述的是基于Windows环境的学生管理系统,主要功能模块包括学生信息的添加、修改、查找、删除。主要工具MicrosoftVisualStudio2010设计窗体,SQLserver2008建立数据库,实现学生信息管理的基本功能。本篇报告介绍一个学生信息管理系统的从分析到设计最后
推荐度:
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top