C学生信息管理系统_第1页
C学生信息管理系统_第2页
C学生信息管理系统_第3页
C学生信息管理系统_第4页
C学生信息管理系统_第5页
已阅读5页,还剩17页未读 继续免费阅读

下载本文档

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

文档简介

1、洛阳理工学院课程设计报告课程名称高级语言C#课程设计设计题目学生信息治理系统专业计算机科学与技术班级B130506学号姓名张葵完成日期课程设计任务书设计题目:学生信息治理系统教务员可以输入学生、教师、班级、课程信息,一个班级只属于一 个专业,一个学生只属于一个班级.教务员负责输入每个专业、每个班 级需要学习哪些课程,指定课程的任课教师.一个教师可以教授多个班 的多门课程.教师可以查看学习该课程的学生名单.课程结束后,教师可以录入 课程成绩.课程分两类,必修课和选修课.学生可以选修课程,每学期几门.学生可以查看自己各门课程的成绩.学生还可以进行评教,给老师打分.系统治理员可以输入教室信息,并结合

2、班级、课程、教室信息实现 自动排课.指导教师:张文学2021年12月27日成绩:课程设计评语指导教师:2021年12月31日目录第 1 章 需求和可行性分析需求分析学生 信息 管 理系 统是 一个 教育 单位 不可缺 少 的部 分 ,它的 内容 对于 学校的决策者和治理者来说都至关重要.学校的治理人员可以通过电 脑对学生信息进行有效的治理,预防了以往人工治理的复杂和耗时费 力的劳动,也大大的能够减少治理人员的工作量,可以有效的节约学 校的开支.功能需求作为一个学生的信息治理系统,必须要有治理人员能够进行对学生的信息进 行有效的治理,因此,系统必须预留一个治理员的登录窗口和登录之后所能进行 的操

3、作,在学生信息治理系统中,治理员具有最高的权限,可以对学生、老师、 班级、专业等等进行添加、删除、修改个查询.除了拥有治理员之外,还应该拥有教务处对学生进行治理,例如:对学生课程,成绩等等具有一定的权限.此外,还应该有老师的一个权限,老师在带完一门课之后可以对学生进行一个成绩录入 和平时布置作业的功能.最后是学生自己拥有的功能,学生在测试结束后可以利 用系统登录自己的账户对成绩进行查询.在学生信息治理系统中,要明确各类用户所能拥有的最高权限,如果一旦权 限的问题搞错以后,整个系统就会变得没有价值.例如:学生只有对成绩的查询 功能,而不能对成绩拥有修改和删除以及插入的功能.老师只能够对学生进行成

4、 绩的录入和平时布置作业,而不能删除学生的个人信息等权限.要设立不同的异常机制,这样不会由于用户的错误的操作而使得系统瞬时奔 溃.我们要在代码中设置不同的异常抛出机制,这样就可以使得用户在进行了错 误的或者违反规那么的操作之后,系统不会出现忽然的停止运转.可行性分析随着计算机语言和数据效劳的不断开展,使得许多的现实问题都可以利用计 算机来帮助人类实现轻巧,方便的治理.在教育上,学生是一个庞大的群体,因 此技术人员早早就开始想方法解决这个问题,因此,目前对于学生信息的治理各 种语言都能够编写出一套完整的、可用的学生信息治理系统.技术可行性在这套系统的开发中,采用的是开发语言是C#,软件是Visi

5、o Studio2021 ,C#是微软对问题的解决方案.C#是一种最新的、面向对象的编程语言.它使得程 序员可以快速地编写各种基于 Microsoft 平台的应用程序, Microsoft .NET 提供 了一系列的工具和效劳来最大程度地开发利用计算与通讯领域.正是由于C#面向对象的卓越设计,使它成为构建各类组件的理想之选-无论 是高级的商业对象还是系统级的应用程序.使用简单的C#语言结构,这些组件可以方便的转化为 XML 网络效劳,从而使它们可以由任何语言在任何操作系统上通 过 Internet 进行调用.最重要的是,C#使得C+程序员可以高效的开发程序,而绝不损失C/C+原有的强大的功能.

6、由于这种继承关系,C#与C/C+具有极大的相似性,熟悉类似语言的开发者可以很快的转向 C#.数据库采用的是SQL Server2021R2,这个SQL数据库版本是微软公司推出的 针对微软用户的一种关系型数据库,语言简单,实用.与 Visio Studio 2021 结 合相对简单实用.经济可行性现在随着互联网络、计算机技术的开展,数字城市成为当前热点话题.同时 在国家政策给予大力支持的条件下,这些技术热点给社会产生了极大的影响,不 仅给生活、学习和治理带来了新的体验,同时也带动了经济的增长.学生治理系统使用比拟简单的 C#语言开发,而且目前中国的学校和教育机构 众多,许多的地方都需要用到这套学

7、生信息治理系统,因此学生信息治理系统具 有广阔的市场前景和开展动力.第 2 章 系统设计概述整体设计概述这套学生信息治理系统旨在为用户提供更加有效的、方便的和快捷的学生的 治理系统.本套系统在结构上由数据库和高级语言两局部组成,数据库局部负责 此套系统所要用到的所有的数据库的表的创立和所用到的存储过程的创立.C#部分是具体的设计 UI 界面和具体的逻辑实现,用户可以通过在自己电脑上点击 UI 上的控件进行操作.设计流程图1整体设计思路图设计思路这套学生信息治理系统是由数据库和业务逻辑层和UI层三局部构成,用户在UI层上进行操作,数据通过业务逻辑层数据传至数据库,对数据库中的数据进行 修改,在用

8、户需要用到数据库中的数据时,数据会从数据库中提出经过业务逻辑 层上传至UI层,以供用户查阅和进行其他的操作. 业务逻辑层主要负责的工作就 是将UI传来的数据进行分析,并且做出判断,然后根据判断出的结果进行对数据 库的访问.数据库的主要任务就是为系统提供数据的存储.功能模块介绍以下会对本套系统中的主要模块做一个简单的介绍与分析学生信息模块学生模块的主要功能是对自己的成绩能够有效的进行查询和能够对教师做出 有效的评价在学期末.每个学生只能够对自己的成绩进行有效的查询,在登录自己的账户之后,其 他的同学的成绩是不可见的,这样也是起到了一种隐私的保护作用,而且学生在 登录自己的账户之后没有成绩修改和添

9、加以及删除的功能.图2学生用户登录教师模块教师在使用该系统时,主要的任务是向学生下达作业任务和在期末测试结束 之后给给学生录入成绩,使得学生能够通过自己的账户登录该系统之后能够看到 自己的成绩.在录入成绩之后不能对学生的成绩进行修改.叱Lacher沁w'尸引卡屮1课琨:计算机科学与申杳看名单录入成绩学号姓名班级号课程容制卜B13050620张葵B130506计算机科学与.39513050625李飞B13O60&计算机科寧与图3教师用户登录教务员模块教务员使用该套系统的主要目的是对教室进行治理, 的具体课程情况对班级进行排课.以及能够根据各个班级口- a-cm idec_hQY;

10、O回专业;辭1-班级;JlQSQl¥慄程:勒帀:专业名班级号课程名课时数_学分计算机B130506计聲机科学与.644计算机B13050664&计算机913J5W322计算机B130506643¥图4教务员登录治理员是此套系统的拥有最高的权限,他可以添加学生、老师和教务员的信 息,以及进行修改和删除等等.图5治理员登录第3章 数据库的搭建和实现数据库设计概述数据库在现代的系统的开发中,起到了非常重要的作用.数据库可以对数据 起到一种长期保存的效果,而且可以利用终端随时随地的通过网络来访问效劳器, 进而访问数据库,找到自己想要的数据和信息.E-R图的设计ER图在设计数

11、据图的时候起到了非常关键的作用, 可以从ER图中清楚的看到 各个对象之间的关系和它具有的属性,因此,在创立数据库的时候会更加的方便 和得心应手.图6学生的ER图图7教师的ER图图8教务员ER图图11课程ER图图12成绩ER图数据库表的创立数据库中的数据都是通过表来进行存储的,因此,要将数据存储到数据库中, 必须将表的结构进行合理化的设计,ER图为表的创立提供了良好的理论支撑,现 在在建表的时候要考虑的是数据的存储大小,我们现在采用可以变换大小的 varchar ()类型进行存储,这样不会导致内存的无故浪费.图13整体表的创立学生表中主要是学生的一些属性,例如学生的学号,姓名,年龄和性别等等,

12、在学生治理系统中,学号作为该表的主键,设计如下:图14学生表的创立教师表的创立教师表中也是教师的一些属性,例如教工号、姓名和教室名等等,教工号为主键, 设计如下:图 15 教师表的创立课程表的创立在课程表中,属性是关于课程的一些信息,例如课程号、课程名和该课程的 学时和学分.课程号是主键 , 设计如下:图 16 课程表的创立在创立完学生表和课程表之后,需要一个成绩表来显示学生的成绩信息,成 绩要与学生个人和课程能够匹配上,在这里,需要设置学号和课程号为主键,而 学生表中的学号和课程表中的课程号都是外键,设计如下: 图 17 成绩表的创立存储过程的创立在使用数据库的时候有时候不是一个表所能完成的

13、一项任务,我们往往会采 用存储过程进行多表的结合使用,例如:要查询某个专业下的某个年级的某个班 的一位同学的信息并且把这些信息显示出来,这样就会涉及到专业表、年级表、 班级表和学生表.因此,在这个时候我们需要将多表进行结合使用,这里就会使 用到存储过程. 在本套系统中, 我采用了几个存储过程来对学生的信息进行治理 图 18 整体的存储过程分配班级存储过程在分配班级的时候要用到班级和专业两个表,因此要通过这两个表进行分配, 从而确定某一个班是属于哪一个专业,代码如下:USE student_adminGOSET ANSI_NULLS ONGOSET QUOTED_IDENTIFIER ONGOA

14、LTER PROCEDURE dbo.CLASS_CHOOSEpro varchar(20), cla varchar(20)asselect professional. 专 业 名 ,class. 班 级 号 ,course. 课 程 名 ,course. 课时数 ,course. 学分from professional,course,classwhere professional. 专业号 = class. 专业号 and professional. 专业名 = pro and class. 班级号 = cla班级信息的存储过程查询某一个班级信息的功能,这个功能函数既可以在数据库中用存储过

15、程实现也可以在C#中通过语言的逻辑来实现,在这套系统中,我采用的是利用在数据 库中建立了一般班级信息的存储过程来实现的,在C艸通过调用该存储过程,然后向其中传递一个参数就可以实现.代码如下:USE student_adminGOSET ANSI_NULLS ONGOSET QUOTED_IDENTIFIER ONGOALTER procedure dbo.class_messageclassno varchar(20)asselect 班级号,专业名,班主任,班长, 人数from classwhere 班级号 = classno学生课程的存储过程学生的课程信息不仅仅包含了学生类,而且还包含了课

16、程类,我们需要将这 两个表进行有效的结合进行使用,在这套系统中我采用的是利用在数据库中建立 一个学生课程的存储过程来显示学生的课程信息,预留一个输入参数学生的学 号,可以利用学号就可以查询到该学生的课程信息.代码如下:USE student_adminGOSET ANSI_NULLS ONGOSET QUOTED_IDENTIFIER ONGOALTER procedure dbo.student_coursecourseno varchar(20)asselect student.学号,student.姓名,student.班级号,course.课程名 ,grade. 分数from stud

17、ent,course,gradewhere student. 学号 = grade. 学号 and course. 课程号 = grade. 课程号 and 课程名 = courseno 在学生治理系统中,非常重要的一环就是学生可以查看自己的成绩,在这套 系统中,采用的也是在数据库中建立一个关于学生的存储过程,是根据学号进行 查询的,在C#中,调用该存储过程,输入一个学号的参数,便可以查询该学生的 成绩信息,预防查询了其他人成绩,起到隐私保护的作用.代码如下:USE student_adminGOSET ANSI_NULLS ONGOSET QUOTED_IDENTIFIER ONGOALTE

18、R procedure dbo.student_gradestudent_id varchar(20)asselect student.学号,student. 姓名,course.课程名,grade.分数, choose. 选课名 ,grade. 选修分数 from student,course,grade,choosewhere student. 学号 = grade. 学号 and choose. 选课号 = grade. 选课号 and student. 学号 = student_id第4章C#高级语言的实现概述在数据库进行完设计之后,就要使用C#这种高级语言将他真正的能够和用户产生联系

19、,用户接触到的是 UI层面,因此我们的任务就是通过 UI层进行数据传 递到业务逻辑层然后进行数据的转化和业务逻辑的实现.数据库的连接在本套系统中,连接数据库我采用的是利用数据源来连接数据库,这样就可 以将连接数据库的字符串和commo都封装在数据源中,为每个表都创立好数据源 和数据适配器,这样可以减少代码量,而且也会使得程序变得简洁明了,在使用 一个数据库中的某一个表的时候只需要创立一个该表的数据适配器和一个共有的 dataset即可.关系图如下:M器二常當C *-比圏Ijns图19数据源图示开始界面的设计开始界面主要是让用户选择自己的身份类型进行系统的登录.如果用户选择 的是系统治理员的登录

20、方式,系统会自动的进行页面的跳转,跳转到系统治理员 的登录界面.图 20 登录类型选择系统治理员登录功能和界面登录界面主要是让用户输入账号和密码进行登录,界面的风格是一致的,只 是通过调用不同的数据库的信息进行不同的登录.图 21 登录界面用户在输入账号和密码的时候,系统会调用数据中的相应的表进行查看是否 与表中的数据匹配,如果匹配那么能够登录成功,否那么不成功.如果登录成功,该 账号和密码会被记录到本地的文件中进行存储,以此到达下次登录时的快捷和方 便,代码如下:private void button1_Click(object sender, EventArgs e)oString();pass = row12.ToString();catch (Exception ex)5if (name =oString();= datarow11.ToString();= datarow12.ToString();= datarow13.ToString();= datarow14.ToString()

温馨提示

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

评论

0/150

提交评论