学校管理系统开发报告.docx
《学校管理系统开发报告.docx》由会员分享,可在线阅读,更多相关《学校管理系统开发报告.docx(15页珍藏版)》请在冰豆网上搜索。
学校管理系统开发报告
摘要
随着信息技术在管理上越来越深入而广泛的应用,信息管理系统的实施在技术上已逐步成熟。
信息管理系统是一个不断发展的新型学科,任何一个单位要生存要发展,要高效率地把内部活动有机地组织起来,就必须建立与自身特点相适应的信息管理系统。
本文采用VB和ACCESS等软件为开发工具,以WindowsXP(或Windows2000)为开发平台,设计出一个学校管理系统,对学生、员工的信息、学生的课程以及成绩进行统一管理,便于查询、修改和打印。
主要实现的功能模块有系统管理子系统、学生信息管理子系统、员工信息管理子系统、班级信息管理子系统、课程信息管理子系统、成绩信息管理子系统、综合测评子系统、毕业管理子系统、图书馆管理子系统等。
本系统界面友好,操作简单,较为实用。
系统分析
一、需求分析
一个功能齐全、简单易用的信息管理系统不但能有效地减轻学校各类工作人员的工作负担,它的内容对于学校的决策者和管理者来说都至关重要。
所以学校管理系统应该能够为用户提供充足的信息和快捷的查询手段。
但一直以来人们使用传统人工的方式管理文件档案、统计和查询数据,这种管理方式存在着许多缺点,如:
效率低、保密性差,人工的大量浪费;另外时间一长,将产生大量的文件和数据,这对于查找、更新和维护都带来了不少困难。
随着科学技术的不断提高,计算机科学日渐成熟,其强大的功能已为人们深刻认识,它已进入人类社会的各个领域并发挥着来越重要的作用。
作为计算机应用的一部分,使用计算机对学校的各类信息进行管理,具有手工管理所无法比拟的优点.例如:
检索迅速、查询方便、效率高、可靠性好、存储量大、保密性好、寿命长、成本低等。
这些优点能够极大地提高学校信息管理的效率,也是一个单位科学化、正规化管理,与世界接轨的重要条件。
因此,开发这样一套管理软件成为很有必要的事情,我们通过自己的知识和大量书籍的翻阅、网站的查阅,一起合作开发了一个学校管理系统。
该项目开发的软件为学校管理系统软件,是鉴于目前学校学生、员工人数和图书馆信息剧增,信息呈爆炸性增长的前提下,学校对信息管理的自动化与准确化的要求日益强烈的背景下构思出来的,该软件设计完成后可用于所有教育单位(包括学校,学院等等)的信息的管理.目前社会上信息管理系统发展飞快,各个企事业单位都引入了信息管理软件来管理自己日益增长的各种信息,学校管理系统也是有了很大的发展,商业化的信息管理软件也不少.但本系统完全独立开发,力求使系统功能简洁明了,但功能齐全且易于操作.
学校管理信息系统是一个以计算机为工具,对学校管理信息进行处理的人—机系统,它能准确统计出学生的考试分数,能从全局出发辅助学校各职能部门以及校长管理学校。
可见,学校管理系统首先必须具有强大的电子数据处理功能,能大大提高学校管理人员的工作效率,减轻劳动强度,同时,该系统应当采用管理模型,将仿真、优化等现代决策手段结合起来,为学校管理层的决策提供有效信息。
本系统的用户类型可分为三种:
管理员、普通用户
管理员:
拥有一切权限,可管理用户,修改,删除数据。
普通用户:
只能查看数据,不得修改删除数据。
整个系统,包括了学生信息管理、员工信息管理、班级信息管理、课程信息管理、成绩信息管理、综合测评、毕业管理等。
基本符合学校管理的需求。
在仔细分析有关学校管理系统的基础上,我们以学生信息管理的模块为例,说明本系统的数据流程图,如图所示:
二、可行性分析
(一)技术可行性分析
1、选用的设计语言
本系统采用面向对象的软件开发方法,以Microsoft公司的可视开发环境VisualBasic6.0作为主要开发工具,使用MicrosoftAccess2000作为关系数据库,并在VB编程语言中采用ADO数据库编程模型,配合功能强大的查询语言实现建立关系数据库,访问数据库,对数据库的更新,较好地实现了预定的需求功能。
VisualBasic6.0是一种可视化、面向对象和采用事件驱动方式的结构化高级程序设计语言,可用于开发Windows环境下的各类应用程序。
它简单易学、效率高、且功能强大。
在VisualBasic环境下,利用事件驱动的编程机制、新颖易用的可视化设计工具,使用Windows内部的应用程序接口(API)函数,以及动态链接库(DLL)、动态数据交换(DDE)、对象的链接与嵌入(OLE)、开放式数据连接(ODBC)等技术,可以高效、快速地开发出Windows环境功能强大、图形界面丰富的应用软件系统。
VisualBasic6.0是专门为Microsoft的32位操作系统设计的,可用来建立32位的应用程序。
在Windows9x、WindowsNT或Windows2000环境下,用VisualBasic6.0的编译器可以自动生成32位应用程序。
这样的应用程序在32位操作系统下运行,速度更快,更安全,并且更适合在多任务环境下运行。
2、选用Access作为后台数据库
Access2000就是关系数据库管理工具,数据库能汇集各种信息以供查询、存储和检索。
Access的优点在于它能使用数据表示图或自定义窗体收集信息。
数据表示图提供了一种类似于Excel的电子表格,可以使数据库一目了然。
另外,Access允许创建自定义报表用于打印或输出数据库中的信息。
Access也提供了数据存储库,可以使用桌面数据库文件把数据文件置于网络文件服务器,与其他网络用户共享数据库。
Access是一种关系数据库管理工具,关系数据库是已开发的最通用的数据库之一。
如上所述,Access作为关系数据库开发具备了许多优点,可以在一个数据包中同时拥有桌面数据库的便利和关系数据库的强大功能。
作为应用程序与OLEDB连接的桥梁,ActiveXDataObjects(ADO)为VisualBasic6.0下开发的应用程序访问本地或远程数据库提供了有效的手段。
MicrosoftActiveXDataObjects(ADO)主要优点是易于使用、高速度、低内存支出和占用磁盘空间较少。
ADO支持用于建立基于客户端/服务器和Web的应用程序的主要功能。
在VB中,可以使用开发环境提供的ADO控件,数据库访问方法,对ACCESS中建立的关系数据库简单快捷的进行访问。
在数据库方面,主要采用了ADODC的绑定方法。
ADO是微软公司最新推出的数据访问技术,他特别设计用来访问OLEDBPRIVDER一起协同工作,以提供通用数据访问(UNIVERSALDATAACCESS),OLEDB是底层的数据访问接口,ADO控件使用数据对象来快速建立数据绑定的控件和数据提供者之间的连接。
ADO的全名是ActiveXDataObject(ActiveX数据对象),是一组优化的访问数据库的专用对象集,它为ASP提供了完整的站点数据库解决方案,它作用在服务器端,提供含有数据库信息的主页内容,通过执行SQL命令,让用户在浏览器画面中输入,更新和删除站点数据库的信息。
ADO主要包括Connection,Recordset和Command三个对象,它们的主要功能如下:
·Connection对象:
负责打开或连接数据库文件;
·Recordset对象:
存取数据库的内容;
·Command对象:
对数据库下达行动查询指令,以及执行SQLServer的存储过程。
比较而言:
ODBC–(OpenDatabaseConnectivity)是第一个使用SQL访问不同关系数据库的数据访问技术。
使用ODBC应用程序能够通过单一的命令操纵不同的数据库,而开发人员需要做的仅仅只是针对不同的应用加入相应的ODBC驱动。
DAO-(DataAccessObjects)不像ODBC那样是面向C/C++程序员的,它是微软提供给VisualBasic开发人员的一种简单的数据访问方法,用于操纵Access数据库。
RDO–在使用DAO访问不同的关系型数据库的时候,Jet引擎不得不在DAO和ODBC之间进行命令的转化,导致了性能的下降,而RDO(RemoteDataObjects)的出现就顺理成章了。
OLEDB–随着越来越多的数据以非关系型格式存储,需要一种新的架构来提供这种应用和数据源之间的无缝连接,基于COM(ComponentObjectModel)的OLEDB应运而生了。
综上所述ADO–基于OLEDB之上的ADO更简单、更高级、更适合VisualBasic程序员,同时消除了OLEDB的多种弊端,取而代之是微软技术发展的趋势。
所以我们采用ADO的方法来绑定数据库,能够达到功能的要求。
(二)经济可行性分析
成本方面,关于各种软、硬件及辅助设备的购置、调试、机房及辅助设施(电源等)以及系统维护,内务开销这些费用都可以忽略不计,因为我们信息系机房可以为我们免费提供一切。
拥有了天时、地利、人和,我们只需充分利用这些资源来开发我们的学籍选课管理系统即可,可谓成功在望.
就拿该系统中的学生学籍选课管理子系统为例,省去了老师为学生展示学校为学生提供的选修课程,并作介绍,考试后把分数抄录多次以做备案和公告这些大量繁杂而由单一枯燥的劳动,可以让老师把精力放在教学和组织教学等更重要更具创造性的事情上,这就显著的提高了他们的工作效率。
取消了抄录成绩后,学校里也不会再出现残破的成绩单一层盖一层的贴在公告栏或黑板上的情景,校园环境也会因此而变得更整洁,而且也为学校省下了大量的纸张,虽然数量并不是很多,但将来系统扩展到整个学校也将是很可观的。
况且,在资源日益缺乏的今天,节省纸张已不仅仅是为学校减少办公费用这一单纯的意义。
众所周知,现在大学的学生多,课程重,管理起来非常困难。
相应的也加大了老师的工作量,又因为教学制度的不断变动和改革,因此,总能及时统计出一份内容清晰,条理性强的学籍学分选课分析报表对老师来说真是难于登天。
但如果缺少这份报表,同学们就无法清楚了解自己的学分情况,盲目选课,打乱了学习计划,加重了课业负担,而那些基本顺从课程安排的同学则浪费了许多去学习有用知识的时间,甚至临毕业时却发现未修够学分而毕不了业。
这个关系到每个人命运的问题绝对马虎不得。
不能再坐以待毙了,我们这套学生学籍选课管理系统将提供一份完整的学分选课报表,并会利用管理系统的易修改性及时进行更新,让同学们在选择课程,计算学分中更加游刃有余。
近几年来,我们北京化工大学一直都在扩招学生,外地生源的比例也比以前大了许多,而且还有日益增多的外国留学生,在管理上更增加了管理人员的劳动量,如此多的档案资料,以原有的工作人员数量要管理好实在不容易,但如果增加工作人员,管理成本必然也会增加,得不偿失,而我们这套系统这时就会发挥出它大大的作用,让实用这领会到它的优越之处,帮助老师轻轻松松管理好学生各方面的资料,无论学生是多是少,一切都会被管理得井井有条。
(三)社会可行性
经过我们的调查,绝大部分的任课老师,行政人员和校领导都为现行系统的繁琐和冗杂的工作量所深深困扰着。
在得知我们开发这套系统的计划后,他们都有一种守得云开见月明的感觉,并表示非常愿意在系统的开发过程中给予全力支持以及积极的配合。
我们这套学校管理系统不仅能够让老师更清晰的掌握自己学生的信息,同时也让学生自己更容易的知道如何准确的选课,如何计算学分及尽早得知自己的考试成绩。
这就大大的为老师提供了便利。
比如,在每学期期末考试后,大多数学生都已回到家中,如果为了获取考试成绩又不得不再返回学校的话,既费时又费力,学生牢骚满腹,老师也不能提早放假休息。
而我们的系统可以提供网上查分,同学们在家中只需要上网就可以在第一时间知道自己的成绩。
还有,学生们也可通过我们的系统进行选课来凑够学分完成学业。
在系统中会显示出个门课程的性质(如必修、限选、任选),其所占学分及任课老师的资料,其应用性之强得到充分发挥。
我们学校的电脑普及率已达到了很高的水平,尤其是我们系拥有设备先进管理完善的系机房,而信息学院的老师和学生们对电脑的操作也是驾轻就熟。
因此,只要我们这套学生学籍选课系统操作简单,实用,合理,大家肯定是乐于接受并积极响应和支持的。
对于这一点,我们是很有信心的。
随着信息时代的来临,学籍学分选课等信息管理的自动化,一体化正是大势所趋。
另外,据我们所知,在我们的一些兄弟院校中早已有了相应的系统,他们的师生也强烈体会到了这个系统的务实与便捷之处,因此,我们学校作为北京市的重点院校之一,当然也不能甘于落后,尤其是我们信息学院再这方面就更要走在大家的前列,跟上时代潮流,为其他院系做出榜样,也为系统的普遍应用做铺垫。
系统设计
一、总体设计
(一)基本框架
本系统是一个学校管理系统,其下有四大模块,即三大子系统:
信息管理系统,学籍管理系统,宿舍管理系统以及图书馆管理系统。
1.信息管理系统:
a.学生信息:
基本信息:
学号、班级、宿舍、姓名、住址、电话等
体检信息:
入学体检、毕业体检
b.教职工信息:
基本信息:
姓名、教授课程、部门等
档案:
姓名、住址、电话等
2.学籍管理系统:
a.学生成绩管理:
成绩录入、成绩查询、不及格名单、学生总分名次、综合测评表、班级查询、设置年级课程等
b.员工培训管理:
员工姓名、培训课程、培训费用等。
3.宿舍管理系统:
4.图书馆管理系统:
(二)系统功能模块设计
系统的功能模块图如下:
宿舍管理系统
学生信息管理部分分为基本信息、体检信息两部分。
员工信息管理部分分为基本信息和培训信息两部分。
员工培训信息部分可以浏览所有员工培训的资料,添加新的培训资料,修改需要改的信息。
班级信息管理部分分为班级查询和班级浏览两部分。
班级查询部分可以依各条件查询所有班级信息。
班级浏览部分支持资料的修改和删除以及班级资料的报表打印。
课程信息管理部分分为学校基本课程,各班课程设置两部分。
学校基本课程设置部分提供所有课程的设置,可以查询、添加、删除、筛选。
各班课程设置部分则根据各个班级情况从已经设置好的基本课程中选择所需要的课程,或者删除不需要的课程,同样支持报表打印。
成绩信息管理部分分为学生成绩信息、补考/重修/积考成绩输入和学生成绩查询三部分。
学生成绩信息部分可以浏览所有成绩信息,并能输入/修改,支持报表打印。
补考、重修、积考成绩输入部分可以添加/修改补考、重修、积考成绩。
学生成绩查询部分可以查询所有成绩、补考成绩、重修成绩和积考成绩。
综合测评部分分为综合测评信息和综合测评图示两部分。
综合测评信息部分显示所有综合测评资料,并能实现多项查询,支持打印。
综合测评图示部分能依每个人的成绩显示不同的二维图。
毕业管理部分分为毕业设计、实习管理两部分。
毕业设计部分能浏览所有学生的毕业设计资料,并能进行资料的添加/修改。
实习管理部分能浏览所有学生的实习资料,并能进行资料的添加/修改。
图书馆管理部分。
(三)系统的总体流程结构设计
实习管理
毕业设计
创建用户
毕业管理
补考、重修、积考成绩输入
学生成绩查询
综合测评图示
成绩信息管理
综合测评
综合测评信息
学生成绩信息
各班课程设置
学校基本课程
课程信息管理
培训信息
班级查询
班级浏览
基本信息
体检信息
基本信息
学生信息管理
员工信息管理
班级信息管理
MDI主接口
登陆接口
界面接口
如图所示:
图3.1系统的总体结构
此系统主要由四个部分组成,分别是用户添加及登陆部分,学生信息管理部分,员工信息管理部分,班级信息管理部分,课程信息管理部分,成绩信息管理部分,综合测评部分,毕业管理部分以及图书馆部分。
二、详细设计
(一)代码设计
该系统涉及到的代码设计如下,为了简单方便,均使用了顺序码:
学号:
顺序码。
员工号:
顺序码。
课程代号:
四位,顺序码。
(二)数据库设计
数据库在一个信息管理系统中占有非常重要的地位,数据库结构设计的好坏将直接对应用系统的效率以及实现的效果产生影响。
合理的数据库结构设计可以提高数据存储的效率,保证数据的完整和一致。
设计数据库系统时应该首先充分了解用户各个方面的需求,包括现有的以及将来可能增加的需求。
数据库设计一般包括如下两个步骤:
1、数据库需求分析。
2、数据库逻辑结构分析。
1、数据库需求分析:
这个系统使用的数据库是微软Access2000数据库。
其中数据库.mdb,总共有19张资料表。
用户的需求具体体现在各种信息的提供、保存、更新和查询,这就要求数据库结构能充分满足各种信息的输出和输入。
收集基本数据、数据结构以及数据处理的流程,组成一份详尽的数据字典,为后面的具体设计打下基础。
针对学校管理的需求,通过对学校内部管理内容和数据流程分析,设计如下所示的数据项和数据结构:
数据库:
数据库.mdb
资料表13:
学生信息表
列名
数据类型
是否为空
说明
学号
数字
否
姓名
文本
是
性别
文本
是
系别
文本
是
班级
文本
是
政治面貌
文本
是
家庭地址
文本
是
联系电话
文本
是
邮政编码
文本
是
父亲姓名
文本
是
母亲姓名
文本
是
毕业学校
文本
是
入学成绩
文本
是
宿舍号
文本
是
退学
是/否
是
cancel
数字
是
资料表15:
员工信息表
列名
数据类型
是否为空
说明
员工号
数字
否
姓名
文本
是
性别
文本
是
职称
文本
是
培训时间
文本
是
培训部门
文本
是
培训费用
文本
是
培训课程
文本
是
培训性质
文本
是
培训情况
文本
是
资料表16:
员工信息表
列名
数据类型
是否为空
说明
员工号
数字
否
姓名
文本
是
性别
文本
是
政治面貌
文本
是
教授课程
文本
是
所属部门
文本
是
职称
文本
是
工资级别
数字
是
联系电话
数字
是
家庭住址
文本
是
Cancel
数字
是
资料表2:
班级表
列名
数据类型
可否为空
说明
年级
文本
是
教室
文本
是
专业
文本
否
年制
文本
是
班主任
文本
是
备注
文本
是
Cancel
数字
是
资料表6:
各班课程
列名
数据类型
是否为空
说明
专业
文本
是
学期
文本
是
课程代号
文本
是
课程名称
文本
是
Cancel
数字
是
资料表1:
按课程类型
列名
数据类型
可否为空
说明
课程类型
文本
否
cancel
数字
是
资料表8:
教材表
列名
数据类型
是否为空
说明
课程代号
文本
是
课程名
文本
是
教材
文本
是
资料表9:
课程总表
列名
数据类型
是否为空
说明
课程代号
文本
否
课程名
文本
是
课程类型
文本
是
课时数
文本
是
教学要求
文本
是
学分
文本
是
学期
文本
是
Cancel
数字
是
资料表10:
年级表
列名
数据类型
是否为空
说明
年级
文本
否
料表4:
补考表
列名
数据类型
是否为空
说明
学号
文本
是
姓名
文本
是
课程代号
文本
是
课程名称
文本
是
学期
文本
是
成绩
文本
是
Cancel
数字
是
资料表5:
成绩表
列名
数据类型
是否为空
说明
学号
文本
是
姓名
文本
是
课程代号
文本
是
课程名称
文本
是
学期
文本
是
成绩
文本
是
绩点数
文本
是
Cancel
数字
是
资料表7:
积考表
列名
数据类型
是否为空
说明
学号
文本
否
姓名
文本
是
课程代号
文本
否
课程名称
文本
是
学期
文本
是
成绩
文本
是
Cancel
数字
是
资料表12:
学期表
列名
数据类型
是否为空
说明
学期
文本
是
资料表14:
用户表
列名
数据类型
是否为空
说明
组名称
文本
是
组密码
文本
是
用户名
文本
否
密码
文本
是
资料表17:
重修表
列名
数据类型
是否为空
说明
学号
文本
是
姓名
文本
是
课程代号
文本
是
课程名
文本
是
学期
文本
是
成绩
文本
是
Cancel
数字
是
资料表18:
综合测评表
列名
数据类型
是否为空
说明
学号
文本
否
姓名
文本
是
政治思想分
文本
是
学业成绩
文本
是
科技创新能力分
文本
是
社会实践能力
文本
是
体育锻炼
文本
是
附加/减分
文本
是
2、数据库逻辑结构分析:
下图以部分E-R图设计说明:
1
M
N
M
N
1
N
1
班级设置
课程设置
学生
上课
属于
属于
班级(年级,专业,年制,班主任,备注)
毕业设计(学号,毕业设计课题名,姓名,指导老师名,指导老师所在)
成绩(学号,课程代号,姓名,课程名,学期,成绩,绩点)
课程(课程代号,课程名,课时数,教学要求,学分,学期,课程类型)
学生(学号,姓名,性别,政治面貌,家庭地址,联系电话,父亲姓名,母亲姓名,毕业学校,入学成绩,宿舍号,系别,班级)
员工(员工号,姓名,性别,政治面貌,教授课程,所属部门,职称工资级别,联系电话,家庭住址)
员工培训(员工号,培训课程,姓名,性别,职称,培训时间,培训部门,培训费用,培训性质,培训情况)