学生信息管理系统(5篇材料)

时间:2019-05-14 02:51:38下载本文作者:会员上传
简介:写写帮文库小编为你整理了多篇相关的《学生信息管理系统》,但愿对你工作学习有帮助,当然你在写写帮文库还可以找到更多《学生信息管理系统》。

第一篇:学生信息管理系统

文 摘 要

学生信息,它的工作量可能是其它信息工作量的几倍,班级的增加、班级的查找、班级的修改;学生档案;课程管理;成绩管理;缴费管理;统计等等,每个信息的数据都在不断地变化着,如果采用人工的方式进行操作,那么,一天的工作量,足以让人觉得比较繁琐,吃不消。针对这样的情况,采用让数据的查询变得简单化,数据变的更让每个人都在任何时刻都可以了解到。所以信息管理系统是一个教育单位不可缺少的部分,它的内容对于学校的决策者和管理者来说都至关重要,所以学生信息管理系统应该能够为用户提供充足的信息和快捷的查询手段

学生信息管理系统是为本校开发的,经过我们仔细分析,系统所采用的语言是Visual Basic,用Microsoft Access 2000数据库完成。该系统总体有三部分组成,包括系统登录、学生信息查询、数据库的录入。通过本系统,把本校内部查询学生信息、教务信息、学生选课各个环节进行有效地计划、组织和控制。通过本校内部的信息,依据统一数据信息进行管理,把任何一块信息所产生的数据变动及时地反映给其它相关信息,做到数据共享。

关键词:学生信息管理系统 Visual Basic ACCESS数据库

Abstract Student information, it may be the workload of the workload of the other information several times, the increase in class, the class of search, Class changes;Student files;Course management;performance management;Payment management;Statistics etc., Each of data are constantly changing, if artificial way to operate, then the workload of the day, enough to make people think that the more cumbersome, hard to swallow.In such a case, the data used for inquiries become simplistic, What changed the data every one at any time can be learned.Therefore, the information management system is a unit of education as an indispensable part, its contents for the policy makers and school administrators are of great importance.So student information management system should be able to provide users with sufficient information and efficient means of inquiries Student Information Management System for the development of the University, after careful analysis, the system used by the language is Visual Basic, Microsoft Access 2000 database completed.The whole system has three components, including the system registry, student information inquiries, database input.Through the system, the University Student Information internal inquiry, the Senate information, students classes in all aspects effectively plan, organization and control.By the University of internal information, in accordance with unified data information management, any information from a data reflect changes in a timely manner to other relevant information, so data-sharing

Keywords: Student Information Management System database Visual Basic ACCESS

目录 论 文 摘 要

I ABSTRACT II 目录

III 第1章 绪 论1.1本论文的实际讨论意义第二章 管理信息的基础知识2.1 管理信息系统的概念2.1.1 MIS的结构、特征及相关学科 4 2.2 管理信息系统的产生第三章 系统开发工具——VISUAL BASIC 6.0简介及应用3.1系统功能简介:VISUAL BASIC主要功能特点包括: 3.2开发工具及相关技术简介第四章 数据库ACCESS的基础及应用4.1数据库的概念第五章程序及其分析5.1 程序框图5.2 主界面图:5.3信息查询图表及代码5.4成绩统计表及程序如下:

总结

参 考 文 献

8 第1章 绪 论

学生信息管理是每一所高校都必须面对的工作,特别是近几年来,国家政策的调整,我国高等院校大规模的扩招,给高等院校的教学管理、学生管理、后勤管理等方面都带来不少的冲击。特别是对于学校的决策者和管理者来说学生信息管理工作是至关重要的,但一直以来人们使用传统的人工方式管理文件档案,这种管理方式存在许多缺点,如:效率低、保密性差,学生数量的增加,这必然增加了学生档案管理者的工作量和劳动强度,同时将产生大量的文件和数据,这给学生信息的查找、更新和维护都带来了不少困难。据调查,目前我国各类高等院校中还有相当一部分学生档案管理还停留在纸介质的基础上,尤其是中、小学对学生档案的管理更是落后,这样的管理机制已经不能适应时代发展的要求,其管理方法将浪费许多人力和物力。随着科学技术的不断提高,计算机科学与技术日渐成熟,计算机应用的普及已进入人类社会生活的各个领域,并发挥着越来越重要的作用。这种传统的手工管理模式必然被以计算机为物质基础的信息管理方法所取代。

作为计算机应用的一部分,使用计算机对学生档案进行管理,有着手工管理所无法比拟的优点,如:检索迅速、查找方便、可靠性高、存储量大、保密性好、受命长、成本低等。这些优点能够极大地提高学生档案管理的效率,也是学校向科学化、正规化管理发展的必要条件,更是各个高等院校与世界接轨的重要条件。

因此,开发一套能够为用户提供充足的信息和快捷的查询手段的学生信息管理系统,将是非常必要的,也是十分及时的。借此毕业之际利用自己已掌握的各种专业知识,结合实际应用,开发一个学生信息管理系统来帮助学校进行有效的信息,并将其作为自己的毕业设计课题主要完成一些信息的统计和查询等一些重要的功能

经过分析,我们使用MICROSOFT公司的VISUAL BASIC开发工具,利用其提供的各种面向对象的开发工具,尤其是数据窗口这一能方便而简洁操纵数据库的智能化对象,首先在短时间内建立系统应用原型,然后,对初始原型系统进行需求迭代,不断修正和改进,直到形成用户满意的可行系统。

随着学校的规模不断扩大,学生数量急剧增加,有关学生的各种信息量也成倍增长。面对庞大的信息量需要有学生管理系统来提高学生管理工作的效率。通过这样的系统可以做到信息的规范管理、科学统计和快速查询、修改、增加、删除等,从而减少管理方面的工作量。

本系统主要用于学校学生信息管理,总体任务是实现学生信息关系的系统化、规范化和自动化,其主要任务是用计算机对学生各种信息进行日常管理,如查询、修改、增加、删除,另外还考虑到学生选课,针对这些要求设计了学生信息管理系统本系统主要用于学校学生信息管理,总体任务是实现学生信息关系的系统化、规范化和自动化,其主要任务是用计算机对学生各种信息进行日常管理,如查询、修改、增加、删除,另外还考虑到学生选课,针对这些要求设计了学生信息管理系统。

本系统主要包括学生信息查询、教务信息维护和学生选课三部分。其功能主要有:

⒈有关学籍等信息的输入,包括输入学生基本信息、所在班级、所学课程和成绩等。

⒉学生信息的查询,包括查询学生基本信息、所在班级、已学课程和成绩等。

⒊学生信息的修改。⒋班级管理信息的输入,包括输入班级设置、年级信息等。

⒌班级管理信息的查询。

⒍班级管理信息的修改。

⒎学生课程的设置和修改。

1.1本论文的实际讨论意义

当今社会,计算机已经成为我们学习和工作的得力助手,计算机的价格已经十分低廉,性能却有了长足的进步。它已经被应用于许多领域,计算机之所以如此流行的原因主要有以下几个方面: 首先,计算机可以代替人工进行许多繁杂的劳动;其次,计算机可以节省许多资源;第三,计算机可以大大的提高人们的工作效率;第四,计算机可以使敏感文档更加安全,等等。

在学校中用计算机管理学生档案的意义:现在我国的学校中档案的管理水平还停留在纸介质的基础上,这样的机制已经不能适应时代的发展,因为它浪费了许多人力和物力,在信息时代这种传统的管理方法必然被计算机为基础的信息管理所取代。

作为一个非计算机应用专业的学生,希望可以在次方面可以好好的学习到一些实际的意义。改革的总设计师邓小平同志说过“科学技术是第一生产力”,我希望能用我在学校所学的编制出一个实用的程序来帮助学校进行更有效的学生档案管理及实际应用信息。

1.2实际研究论文的目的

由于现在高校的学生档案的管理趋向于复杂化和多元化,随着计算机的广泛应用,越来越多的高校均采用了计算机化的管理模式。查询、修改、录入、删除等基本操作都采用了计算机的数据库技术。比起以前使用卡片的方法有了很大的进步,方便管理,易于更新,极大的方便了学生档案的管理工作。因此为提高工作效率,减轻校方人员的工作负担,决定开发学生档案管理系统软件。

开发此学生基本信息管理系统软件,以供行政管理人员使用计算机对学生档案信息进行管理,此系统具有着手工管理所无法比拟的优点。例如:检索迅速、查找方便、可靠性高、存储量大、保密性好、寿命长、成本低等。这些优点能够极大地提高学生档案管理的效率,在设计皮系统的同时,也能够为我们提高我们软件开发的能力,学习VB语言编程的技巧,通过本次软件的开发,包括与导师的交流,从中学习了知识、吸取了经验。

第二章 管理信息的基础知识

随着科学技术的不断提高,计算机科学日渐成熟,其强大的功能已为人们深刻认识,它已进入人类社会的各个领域并发挥着越来越重要的作用。作为计算机应用的一部分,使用计算机对单位的各项事务进行科学化的管理有着无法比拟的优点。例如:查找方便、迅速、可靠性高、存储量大、保密性好、寿命长、成本低等。这些优点能够极大地提高公司的工作效率,也是公司管理科学化、正规化并与世界接轨的重要条件。2.1 管理信息系统的概念

管理信息系统(Management Information Systems,简称MIS),是一个不断发展的新型学科,MIS的定义随着计算机技术和通信技术的进步也在不断更新,在现阶段普遍认为MIS 是人为或计算机设备以及其他信息处理手段组成并用于管理信息的系统。包括以下几个基本概念:(1)MIS的对象就是信息。信息是经过加工的对决策者有价值的数据。信息的主要特征是来源分散,数量庞大。信息来源于生产第一线、社会环境、市场以及行政管理等部门。信息具有时间性。

(2)系统是由相互联系、相互作用的若干要素按一定的规则组成并具有一定功能的整体。系统由输入、处理、输出、反馈、控制等五个基本要素组成。

(3)管理信息由信息的采集、信息的传递、信息的储存、信息的加工、信息的维护和信息的使用等五个方面组成。

MIS包括计算机、网络通信设备等硬件成分,也包括操作系统、应用软件包等软件成分,并随着计算机技术和通信技术的迅速发展还会出现更多的内容。2.1.1 MIS的结构、特征及相关学科

1.MIS的结构

MIS由信源、信宿、信息处理、信息用户和信息管理者等五个部分组成。2.MIS的特征

完善的MIS具有以下四个标准:确定的信息需求、信息的可采集性与可加工性、可以通过程序为管理人员提供信息、可以对信息进行管理。MIS具有以下特征:

 具有统一规划的数据库是MIS成熟的重要标志,它象征着MIS是软件工程的产物。

 通过MIS实现信息增值,用数学模型统计分析数据,实现辅助决策。

MIS是发展变化的,MIS有生命周期。

 MIS的开发必须具有一定的科学管理工作基础。只有在合理的管理体制、完善的规章制度、稳定的生产秩序、科学的管理方法和准确的原始数据的基础上,才能进行MIS的开发。因此,为适应MIS的开发需求,企业管理工作必须逐步完善以下工作:

管理工作的程序化,各部门都有相应的作业流程。

管理业务的标准化,各部门都有相应的作业规范。

 报表文件的统一化,固定的内容、周期、格式。

数据资料的完善化和代码化。

3.MIS的相关学科

MIS是一个交叉性的综合性学科,组成部分有:计算机学科(网络通信、数据库、计算机语言等)、数学(统计学、运筹学、线性规划等)、管理学、仿真等多学科。随着科学技术的高速发展,MIS涉及的范围还要扩大。

2.2 管理信息系统的产生

生产技术的进步,社会活动的复杂化,特别是电子信息技术的迅速发展与广泛应用,使得各种管理工作越来越依赖于对信息的管理。信息作为一种资源,使得人们的工作、生活以及思维方式发生了重大的变革,为企业的生产与经营提供了日益完善的手段。信息的采集、传输、加工和利用成为人们特别是信息工作者的主要活动。企业经理的百分之八十的时间用于信息的传输与处理,一些西方发达国家从事信息处理工作的人数多,在二十世纪八十年代就已经占职工总数的百分之五十以上,而美国1993年政府报告“国家信息基础结构:行动计划”中指出“2/3的美国劳动者从事与信息有关的工作,其余1/3工作在高度依赖于信息的产业部门,”这种职工可以成为“知识工作者”,他们主要就是收集、传输和加工信息,包括编辑文件、写报告、分析信息、作计划等。所以现在各行各业对信息的管理要求越来越大。

显然,计算机在问世之初,只是为了想让它来辅助人们进行科学研究中复杂数值方面的计算,以减少劳动强度,提高工作效率。然而,随着计算机科学的不断发展和进步,是它跨越了数值计算领域,进入管理领域,成为信息处理的重要工具。使用计算机进行信息处理始于1954年,开始是计算机处理工资,现在是计算机在处理各种工作,如旅馆结帐、飞机定票、银行存款、电子购物、电话计费等,已经相当普遍。利用计算机的信息管理、处理能力还可以扩大组织拥有信息的用途。当前所未有的挑战是使用计算机神秘般的能力开始信息管理工作,包括高层管理活动和决策等。

2.3管理信息系统的发展及学生信息系统的简介

信息工作的迅速增长,使计算机的应用范围越来越广泛,应用的功能由一般的数据处理走向支持决策。这就导致了管理信息系统的产生。管理信息系统从产生到现在已经经历了电子数据处理系统(如统计系统、工资系统、数据更新系统等),信息报告系统(如生产报告系统、服务状态报告系统、研究状态报告系统等),支持决策系统,综合服务系统(如综合业务数字网络系统、国际互联网等)等几个阶段。但在我国,由于各种原因,管理信息系统的发展处于初级的数据处理阶段,尽管如此,充分利用我们现有的资源和力量,开发一些适合于本企业或本行业的管理信息系统。也非常重要。随着学校的规模不断扩大,学生数量急剧增加,有关学生的各种信息也成倍增长。面对庞大的信息量,有必要开发学生信息管理系统来提高学生管理工作的效率。通过这样的系统,可以做到信息的规范管理、科学统计和快速查询,从而减少管理方面的工作量。

本学生信息管理系统包括学籍信息管理、班级信息管理、课程信息管理、成绩信息管理四大模块。管理员可以拥有完全的权限管理系统,而学生用户只拥有查询学籍信息和查询成绩信息的权限。学籍管理系统是一个教育单位不可缺少的部分,它的内容对于学校的决策者和管理者来说都至关重要,所以学籍管理系统应该能够为用户提供充足的信息和快捷的查询手段。但一直以来人们使用传统人工的方式管理文件档案,这种管理方式存在着许多缺点,如:效率低、保密性差,另外时间一长,将产生大量的文件和数据,这对于查找、更新和维护都带来了不少的困难。随着科学技术的不断提高,计算机科学日渐成熟,其强大的功能已为人们深刻认识,它已进入人类社会的各个领域并发挥着越来越重要的作用。作为计算机应用的一部分,使用计算机对学籍信息进行管理,具有着手工管理所无法比拟的优点。例如:检索迅速、查找方便、可靠性高、存储量大、保密性好、寿命长、成本低等。这些优点能够极大地提高学生学籍管理的效率,也是企业的科学化、正规化管理,与世界接轨的重要条件。因此,开发这样一套学籍管理软件成为很有必要的事情。在下面的各章中我将以开发学籍管理系统为例,谈谈其开发过程和所涉及到的问题及解决方法。

而学籍信息是学校的一项重要的数据资源,学籍管理也是学校的一项常规性的重要工作。而长期以来,学籍管理都是以来人工进行的,面对如此众多的学籍信息,起工作量可想而知。不仅仅浪费了大量的人力物力,而且由于人工管理存在着大量的不可控因素,造成了学籍管理的某些不规范,使得学籍管理陷入“事倍功半”的地步。学生学籍管理系统是一个教育单位不可缺少的部分,它的内容对于学校的决策者和管理者来说都至关重要,所以学生档案管理系统应该能够为用户提供充足的信息和快捷的查询手段。但一直以来人们使用传统人工的方式管理文件档案,这种管理方式存在着许多缺点,如:效率低、保密性差,另外时间一长,将产生大量的文件和数据

第三章 系统开发工具——Visual Basic 6.0简介及应用 3.1系统功能简介:Visual Basic主要功能特点包括: 3.1.1 提供了面向对象(OOP)的可视化编程工具

把程序和数据封装在一起而视为一个对象。设计程序时只需从现有工具箱中拖出所需的对象,如按钮、滚动条等,在屏幕上设计出用户所要求的布局,VB自动产生界面设计代码,程序设计人员只需编写实现程序功能所需的代码即可,因而程序设计的效率大大提高。3.1.2 事件驱动的编程机制

VB中通过事件来执行对对象的操作,一个对象可以有许多事件过程,不同的事件过程对应不同过程代码。VB开发的应用程序,没有明显的开始和结束标志。3.1.3结构化的程序设计语言

具有丰富的数据类型,众多的内部函数,是一种模块化、结构化的程序设计语言,结构清晰、简单易学。

3.1.4交互式开发

传统的应用开发过程由编码、编译和调试代码3个步骤组成。而Visual Basic使用交互式方法开发应用程序,3个步骤之间没有明显的界限。3.1.5Windows资源共享

VB提供的动态数据交换DDE编程技术,可以在应用程序中实现与Windows应用程序建立动态数据交换、在不同的应用程序之间通行功能。3.1.6开放的数据库功能与网络支持

VB具有很强的数据库管理功能。利用数据控件和数据库管理窗口,可以直接建立和编辑MS Access 格式的数据库,并提供了强大的数据存储和检索功能,同时还能直接编辑和访问其他外部数据库,如Dbase、FoxPro、Paradox等。3.1.7 得心应手的应用程序向导

VB中使用了许多应用程序向导,可为用户自动创建多种类型和不同功能的应用程序的初始轮廓,另外还有安装向导、数据窗体向导、IIS应用程序DHTML等,使用起来得心应手,省去了一些烦琐的工作。

3.1.8 完善的联机帮助功能

强大的联机帮助功能和示范代码,设计任何时候,只需按下F1键,就会显示必要的提示,运行时,也会对出现的错误给出一定的提示。

在系统中,充分利用了Access 数据库和Visual Basic 6.0的强大功能,通过实践,也使自己对这些方面有了较深入的了解。在设计过程中力求完善系统功能,使界面友好,具有一定的容错能力,在使用过程中不会出现难以纠正的错误和毛病。

该系统主要提供了六部分,功能分别为导入学生数据,增加删除学生,住宿分配,住宿调整,退房管理,走读管理,学生情况查询,房源使用情况,空床统计情况,分类统计情况,卫生成绩录入,卫生查询与统计,公寓违纪录入,公寓违纪查询,添加用户,修改密码,退出系统,这些功能基本上覆盖了学生公寓管理的主要部分。3.2开发工具及相关技术简介

Visual Basic 6.0 开发语言及环境简介 Visual Basic 6.0是在原有的Basic语言的基础上的进一步发展,他包含了数百条语句。函数及关键词,其中很多与Windows GUI有直接的关系。Visual Basic 语言简单易学,只要稍有语言基础就可以很快的掌握并进而精通。可视化的用户界面设计功能,把程序设计人员从繁琐复杂的截面设计中解脱出来;可视化编程环境的“所见即所得(WYSIWYG)”功能,是界面设计如积木游戏一般,编程变成了一种享受;强大的多媒体功能可轻而易举地开发出集声音,动画,影像和图片于一体的多媒体应用程序;新增的网络功能提供了编写Internet程序的能力。Visual Basic 6.0 还支持用户自己开发ActiveX控件和制作ActiveX文档。

作为高质量的开发软件,Visual Basic 6.0有如下特点:

1.语句生成器和快速提示帮助使用户不必记忆成千上万的属性和方法,在较短的时间内就能开发出功能强大的应用程序。

2.在Visual Basic 6.0中,Internet应用程序的开发功能更加强大和容易。在应用程序内可以通过Internet 或Intranet访问其他计算机中的文档和应用程序;可以创建Internet服务器应用程序,包括IIS应用程序;支持HTML技术(DHTML)的应用程序;具有Web应用程序发布功能等。

3.种类繁多、功能强大的多媒体控件,能帮助用户在较短时间内用较少的语句编写出图文声像并茂的多媒体程序。

4.Visual Basic 6.0在数据库处理功能上有较大增强,能对多种数据库进行读写操作。另外他所提供的[可视化数据管理器]能帮助用户构造多种类型的数据库,同时提供了能自动生成SQL语句的功能和新的ActiveX数据对象ADO。

5.新的语言特征包括:用户自定义类型可以作为参数或作为公共属性和方法的返回值;函数可以返回数组变量;动态数组可以赋值;文件系统对象;按名调用(Call By Name);增强的创建对象函数(CreateObject Function Enhancements);增强的StrConv函数。

6.[应用程序安装向导]能帮助用户自动生成具有一定功能的应用程序,大大加快了程序的开发速度。增强的向导有:安装程序向导、数据窗体向导、应用程序向导和类生成工具。新的向导有:数据对象生成向导和工具条向导。3.3 Visual Basic 语言的特点

Visual Basic 语言用其设计应用程序时具有两个基本特点:可视化设计和事件驱动编程。(1)可视化设计:表现在VB在设计应用于程序界面时有“所见即所得”的处理功能。(2)事件驱动编程:在设计应用程序时,把对象添加到窗体中,在用户与程序进行交互时,用户基本上是通过鼠标、键盘与应用程序进行交互的,那些对象就必须对鼠标和键盘操作所引发的事件做出响应,来执行一段应用程序。

3.4Visual Basic 系统几个在程序应用中的常用名词

Visual Basic 系统除了一般高级语言所具有的一些名词术语外,还有几个系统常用的名词。其基本含义如下:(1)视窗(Form)

视窗是进行人机交互的界面或接口,也叫窗体。VB系统的人机交互界面或接口,无论是在设计时或是在运行时,都是Windows 系统的标准视窗。(2)对象(Object)对象是VB系统内部提供给设计者可以直接使用的处理输出的控制工具。本程序所应用到的对象类型有标签框(Label Box),文本框(Text Box),命令按扭(Command Button),网格(Data Grid),ADO控件(Adodc1)等。当把这些工具放置到用户界面对应的窗体上时,被称为对象或控件。用户可以通过设置对象的“属性”和“方法”,便于对象适应自己所设计应用程序的输入输出内容,对象的生成过程及结构都被封装起来。正确使用对象可以减少程序和开发时间,提高程序设计者的工作效率。(3)属性(Properties)属性是VB系统提供的有关对象的参数或数据接口。用户通过适当地设置或改变对象的属性来确定对象的外观及性能特征,从而有效地使用系统提供的对象。比如,对象的名称、在屏幕上显示的位置、大小、颜色、接收或容纳的数据内容及数据的表现格式等。(4)事件(Events)事件是指用户或操作者对计算机进行的某一操作(如击键、单击或移动鼠标等)的行为或系统状态发生的变化。VB系统常用事件来引导计算机执行一段程序。程序所用的键盘事件有KeyPress(按键)事件,KeyDown事件和KeyUp事件;鼠标事件有Click(单击鼠标)事件,DbDlicd(双击鼠标)。(5)方法(Method)方法主要是指对一个对象使用某种作用的过程。它是在程序执行的过程中要计算机执行的某种操作。其程序的方法有Show(显示)方法,Hide(隐藏)方法,Refresh(刷新)方法。(6)过程(Procedure)过程是指经过定义或说明的,或基于某一对象对应的事件所引发的程序段。(7)模块(Module)模块是指一些运算量或过程进行声明或定义的一个集合。系统程序大体可分成四个模块:数据输入、根据查询、数据打印和通讯。

3.5 面对对象的编程

面向对象的设计方法(OOP, Objected Programming)从应用领域内的问题着手,以直观自然的方式描述客观世界的实体。Visual Basic 作为一种面向对象的编程方法,把程序和数据封装起来作为一个对象,并为每个对象赋予相应的属性。在设计对象时,不必编写建立和描述每个对象的程序代码,而是用工具画在界面上,由 Visual Basic 自动生成对象的程序代码并封装起来。Visual Basic 应用程序基本的构建块是用户所创建的对象,每一个对象都具有一些特性和行为(属性、事件和方法)。开发人员可以最有效利用所创建的每一个对象。使用应用程序具有可通用性可说扩展性和强有力的功能。

Visual Basic 应用由一系列对象组成,包括有函数、菜单、函数、结构和数据窗口、用户对象、用户事件等等,对象中又包含若干控件如命令按钮、单行编辑器等这些对象和控件都可在许多应用中重复使用。3.5.1 实现菜单选项

菜单是程序最重要的特性之一,大多数程序都依赖一个定义良好的菜单使程序易于使用和维护,Visual Basic 也提供了强大的创建菜单功能是程序更加标准。

本系统使用 Visual Basic 的菜单编辑器建立菜单或者修改已经存在的菜单,您也可以使用Visual Basic 的Application Wizard 来操作。3.5.2 实现工具栏

CoolBar控件与Office2000 中看到的CoolBar是类似的。CoolBar就是一个可以在窗体上浮动的工具,同时也是其他ActiveX的容器。通过在CoolBar中迁入其他空间你也可以向用户提供更好的灵活性和义用性。

选择“工程”下拉菜单中的“部件”选项,显示“部件”对话框。在“控件”选项卡列表中选择“Microsoft Windows Common Controls 6.0”后工具相中增加改控件。

本系统就用了Cool工具中的Statubar控件,在系统这一界面中,添加了状态栏,在第一个栏中,在样式这一栏中选择了文本,在第二个栏中,选择了系统日期,第三个栏中选择了系统时间,这样,任何时候操作本系统,都可以看到当前的时间和日期。第四章 数据库Access的基础及应用 4.1数据库的概念 数据库是一种存储数据并对数据进行操作的工具。数据库的作用在于组织和表达信息,简而言之,数据库就是信息的集合。计算机的数据库可以分为两类:非关系数据库(flat-file)和关系数据库(relational)。关系数据库中包含了多个数据表的信息,数据库含有各个不同部分的术语,象记录、域等。

新建一个数据库,创建任何一个数据库的第一步是仔细的规划数据库,设计必须是灵活的、有逻辑的。创建一个数据库结构的过程被认为是数据模型设计。1. 标识需要的数据;

2. 收集被标识的字段到表中; 3. 标识主关键字字段; 4. 绘制一个简单的数据图表; 5. 规范数据;

6. 标识指定字段的信息; 7. 创建物理表。修改已建的数据库

数据库的修改分为:添加、编辑和删除记录。这三种操作均可由Visual Basic 创建的程序来完成,下面的章节将详细描述实现的具体方法。实现数据库之间的联系

数据库之间的关系指明两个库之间共享一个共同的关键字值。一个连接是指一种虚拟的表,这种表是在当用户要求从相互关联的各个不同的表中获取信息时建立的,关键字段用于在相互连接的不同表中查找匹配的记录。一个更高级的连接形式称为自连接。这种连接是指一个表被连接到它自己的一个字段,或在不同的纪录中由重复数据的组合字段。数据库中有三种不同类型的关键字:主关键字、组合关键字和外关键字。在表中使用的关键字类型用于描述库表示什么以及在数据库中如何与其它的库建立关系。

第五章程序及其分析 5.1 程序框图

5.2 主界面图:

5.3信息查询图表及代码 Dim i, j, n As Integer Dim sql As String Private Declare Function GetKeyState Lib “user32” _(ByVal nVirtKey As Long)As Integer Public je As Integer '记忆菜单上次数值,实现数据传送

Private Sub acg_Click()Call asPopup7_Click(False)End Sub

Private Sub addcg_Click()Call asPopup6_Click(False)End Sub

Private Sub addstudent_Click()Call asPopup2_Click(False)End Sub

Private Sub asPopup1_Click(Cancel As Boolean)Grid1.Visible = True Grid2.Visible = False tkbase = “学生信息” fnumber = 13 sql = “select * from ” & tkbase & “ order by 学号 desc” grid1pz '执行grid1的分配空间任务 datagrid '按要求读取数据空间 End Sub Private Sub grid1pz()'处理grid1的操作 Grid1.Cols = fnumber + 1 Grid1.Column(1).Width = 120 Grid1.Column(2).Width = 100 Grid1.Column(3).Width = 80 Grid1.Column(4).Width = 40 Grid1.Column(5).Width = 80 Grid1.Column(6).Width = 30 Grid1.Column(7).Width = 50 Grid1.Column(8).Width = 80 Grid1.Column(9).Width = 60 Grid1.Column(10).Width = 80 Grid1.Column(11).Width = 100 Grid1.Column(12).Width = 100 Grid1.Column(13).Width = 100 Grid1.Column(4).CellType = cellComboBox Grid1.ComboBox(4).Clear Grid1.ComboBox(4).AddItem “男” Grid1.ComboBox(4).AddItem “女” Grid1.Column(5).CellType = cellCalendar Grid1.Column(2).CellType = cellComboBox Grid1.ComboBox(2).Clear Set qy2 = cnn.Execute(“select 班级名称 from 班级”)Do While Not qy2.EOF

Grid1.ComboBox(2).AddItem qy2.Fields(0)qy2.MoveNext Loop Grid1.Column(9).CellType = cellComboBox Grid1.ComboBox(9).Clear Grid1.ComboBox(9).AddItem “团员” Grid1.ComboBox(9).AddItem “党员” Grid1.ComboBox(9).AddItem “无” Grid1.Column(1).Locked = True End Sub

Private Sub asPopup10_Click(Cancel As Boolean)Dim fo2 As CTranslucentForm Set fo2 = New CTranslucentForm fo2.hWnd = Form6.hWnd fo2.Alpha = 90 / 100 * 255 Me.WindowState = vbMinimized Load Form6 Form6.Show 1 End Sub

Private Sub asPopup2_Click(Cancel As Boolean)Grid1.Visible = True Grid2.Visible = False tkbase = “学生信息” fnumber = 13 Set qy1 = cnn.Execute(“select * from ” & tkbase)grid1pz For i = 1 To fnumber Grid1.Cell(0, i).Text = qy1.Fields(i1).Name Next Grid2.Rows = 1 Grid2.Rows = 21 gridsave = True gridedit = False griddel = False Grid2.Column(1).Locked = False Grid2.Column(2).Locked = True Grid2.Column(3).Locked = False Grid2.Column(4).Locked = True End Sub

Private Sub asPopup7_Click(Cancel As Boolean)Grid1.Visible = False Grid2.Visible = True tkbase = “学生与课程” fnumber = 6 sql = “select * from ” & tkbase & “ order by 学号 asc” gridpz2 datagrid gridsave = False gridedit = True griddel = True Grid2.Column(1).Locked = True Grid2.Column(2).Locked = True Grid2.Column(3).Locked = True Grid2.Column(4).Locked = True End Sub Private Sub gridpz2()Grid2.Cols = 8 Grid2.Column(1).Width = 120 Grid2.Column(3).Width = 120 Grid2.Column(1).CellType = cellComboBox Set qy1 = cnn.Execute(“select * from 课程”)Grid2.ComboBox(1).Clear Do While Not qy1.EOF

Grid2.ComboBox(1).AddItem qy1.Fields(0)& “-” & qy1.Fields(1)qy1.MoveNext Loop Grid2.Column(3).CellType = cellComboBox Set qy1 = cnn.Execute(“select 学号,名字 from 学生信息”)Grid2.ComboBox(3).Clear Do While Not qy1.EOF

Grid2.ComboBox(3).AddItem qy1.Fields(0)& “-” & qy1.Fields(1)qy1.MoveNext Loop End Sub

Private Sub asPopup8_Click(Cancel As Boolean)Dim fo2 As CTranslucentForm Set fo2 = New CTranslucentForm fo2.hWnd = Form7.hWnd fo2.Alpha = 85 / 100 * 255 Load Form7 Form7.Show 1 End Sub

Private Sub asPopup9_Click(Cancel As Boolean)End End Sub

Private Sub c1_Click(Index As Integer)'提交内容到函数执行,4为当前菜单(0-4),index是按钮数组名称 cmove 4, Index End Sub Private Sub cmove(s As Integer, i As Integer)'菜单智能移动函数代码S代表菜单的总数,i代表当前移动的是数组名称 Dim j As Integer Dim X, Y, z, x1, y1 As Integer X = s '将x,y,z,x1赋于菜单总数,x存放frame1的固定值 Y = s 'y存放的是移动后的按钮的固定值 z = s 'Z没用上 x1 = s 'X1没用上 j = 0 'j计算按钮的宽度

Do While s > 0 ' 这里是通过重复计算来计算按钮所需移动的总高度

If je > i Then

Do While X > i

Do While Y >= X

j = j + 360 '360是每个按钮的高度

Y = Yj

X = X360

j = 0

Next

End If s = sFre2(y1).Top

Else

Fre2(y1).Height = Fre1.Heightc1(y1).Height

End If

Else

Fre2(y1).Visible = False

End If Next Loop je = i '这里是记忆上次移动的按钮数组编号 End Sub

Private Sub cgdel_Click()Call XPButton6_Click End Sub

Private Sub cgedit_Click()Call XPButton4_Click End Sub

Private Sub delstudent_Click()Call XPButton6_Click End Sub

Private Sub editstudent_Click()Call XPButton4_Click End Sub

Private Sub findcg_Click()If hang = 0 Then Exit Sub End If Grid1.Visible = False Grid2.Visible = True tkbase = “学生与课程” fnumber = 5 sql = “select * from 学生与课程 where 学号='” & Grid1.Cell(hang, 1).Text & “'” gridpz2 datagrid gridsave = False gridedit = True griddel = True Grid2.Column(1).Locked = True Grid2.Column(2).Locked = True Grid2.Column(3).Locked = True End Sub

Private Sub Frame2_DragDrop(Source As Control, X As Single, Y As Single)

End Sub

Private Sub Grid1_MouseUp(Button As Integer, Shift As Integer, X As Single, Y As Single)If Button = 2 Then If gridsave = True Then savestudent.Enabled = True Else savestudent.Enabled = False End If If gridedit = True Then editstudent.Enabled = True Else editstudent.Enabled = False End If If griddel = True Then delstudent.Enabled = True Else delstudent.Enabled = False End If If admin = False Then addstudent.Enabled = False savestudent.Enabled = False editstudent.Enabled = False delstudent.Enabled = False End If PopupMenu student End If End Sub

Private Sub Grid1_RowColChange(ByVal Row As Long, ByVal Col As Long)hang = Row If gridsave = True And Col = 5 Then '确认默认年龄在20岁左右

If Row <> 0 Then Grid1.Cell(Row, 5).Text = Date1 Then

Grid1.Range(nActiveRow, nActiveCol + 1, _

nActiveRow, nActiveCol + 1).Selected

End If

Cancel = True

End If End Sub Private Sub Form_Load()On Error GoTo finish Grid1.SetRegisterInformation “CNwinndy”, “W]vyY-nonvk-unty-Zbl_e-`hms^” '进行注册

Grid2.SetRegisterInformation “CNwinndy”, “W]vyY-nonvk-unty-Zbl_e-`hms^” '进行注册

Label2.Caption = “今天是” & Year(Date)& “年” & Month(Date)& “月” & Day(Date)& “日,欢迎您进入!” Frame2.Visible = False

form1.BackColor = RGB(167, 111, 177)'-------------管理员验证 If admin = False Then c1(3).Enabled = False

asPopup2.Enabled = False '增加学生 asPopup4.Enabled = False '课程管理 asPopup6.Enabled = False '输入成绩 XPButton4.Enabled = False XPButton5.Enabled = False XPButton6.Enabled = False End If With Grid1.AllowUserResizing = True.DisplayFocusRect = False

.ExtendLastCol = True

.Appearance = Flat.FixedRowColStyle = Flat.ScrollBarStyle = Flat

.DefaultFont.Name = “Tahoma”.DefaultFont.SIZE = 8.BackColorFixed = RGB(84, 201, 134)

.BackColorFixedSel = RGB(167, 111, 177)

.BackColorBkg = RGB(198, 229, 211)

.BackColorScrollBar = RGB(167, 111, 177)

.BackColor1 = RGB(231, 235, 247)

.BackColor2 = RGB(198, 229, 211)

.GridColor = RGB(148, 190, 231)

.Column(0).Width = 0 End With With Grid2.AllowUserResizing = True.DisplayFocusRect = False.ExtendLastCol = True.Appearance = Flat.FixedRowColStyle = Flat.ScrollBarStyle = Flat.AllowUserResizing = True.DisplayFocusRect = False.ExtendLastCol = True.Appearance = Flat.FixedRowColStyle = Flat.ScrollBarStyle = Flat.DefaultFont.Name = “Tahoma”.DefaultFont.SIZE = 8.BackColorFixed = RGB(84, 201, 134)

.BackColorFixedSel = RGB(167, 111, 177)

.BackColorBkg = RGB(198, 229, 211)

.BackColorScrollBar = RGB(167, 111, 177).BackColor1 = RGB(231, 235, 247)

.BackColor2 = RGB(198, 229, 211)

.GridColor = RGB(148, 190, 231).Column(0).Width = 0 End With je = 4 Dim fr As Integer Fre1.BackColor = RGB(168, 217, 189)For fr = 0 To 4 Fre2(fr).Visible = False Fre2(fr).BackColor = RGB(106, 137, 188)Next Grid2.Visible = False Call c1_Click(0)Exit Sub finish: MsgBox Err.Description End Sub

Private Sub Grid2_CellChange(ByVal Row As Long, ByVal Col As Long)'使用智能输入 If Grid2.Cell(Row, 1).Text <> “" And Row <> 0 Then Dim length1, length2 As Integer length1 = Len(Grid2.Cell(Row, 1).Text)Do While length2 < length1

length2 = length2 + 1

If Right(Left(Grid2.Cell(Row, 1).Text, length2), 1)= ”-“ Then

Grid2.Cell(Row, 2).Text = Mid(Grid2.Cell(Row, 1).Text, length2 + 1, length1)

Grid2.Cell(Row, 1).Text = Mid(Grid2.Cell(Row, 1).Text, 1, length21)

Exit Do

End If Loop End If End Sub Private Sub Grid2_MouseUp(Button As Integer, Shift As Integer, X As Single, Y As Single)If Button = 2 Then If admin = False Then cgedit.Enabled = False cgdel.Enabled = False

addcg.Enabled = False End If PopupMenu cg End If End Sub

Private Sub Grid2_RowColChange(ByVal Row As Long, ByVal Col As Long)hang = Row End Sub

Private Sub datagrid()griddelete = True '允许删除 gridedit = True If tkbase = ”学生信息“ Then If qy1.State = adStateOpen Then '表状态 qy1.Close End If qy1.Open sql, cnn, adOpenStatic, adLockReadOnly, adCmdText For i = 1 To fnumber Grid1.Cell(0, i).Text = qy1.Fields(i1)Is Nothing Then '空值的处理

Grid1.Cell(i, j).Text = qy1.Fields(j1).Name Next qy1.PageSize = 20 nnum = qy1.PageCount If qy1.PageCount = 0 Then nnum = 1 End If numpage = 1 Label1.Caption = ”共“ & nnum & ”页 第“ & numpage & ”页“ Grid2.Rows = 1 Grid2.Rows = 21 If qy1.RecordCount = 0 Then Exit Sub End If qy1.AbsolutePage = numpage For i = 1 To qy1.PageSize '设定读取行 For j = 1 To fnumber '设定读取列

If qy1.EOF = True Then Exit Sub End If If Not qy1.Fields(j1)Else Grid2.Cell(i, j).Text = ”“ End If Next If qy1.EOF = False Then qy1.MoveNext '读取下一记录 Else Exit Sub End If Next End If End Sub

Private Sub Grid2_Validate(Cancel As Boolean)

Dim nActiveRow As Long, nActiveCol As Long

Const VK_TAB = 9

If GetKeyState(VK_TAB)< 0 Then

nActiveRow = Grid1.ActiveCell.Row

nActiveCol = Grid1.ActiveCell.Col

If nActiveCol < Grid1.Cols1 qy1.AbsolutePage = numpage Grid1.Rows = 1 Grid1.Rows = 21 For i = 1 To 20 '设定读取行 For j = 1 To fnumber '设定读取列

If qy1.Fields(j1)End If Next qy1.MoveNext '读取上一记录 Next End If Label1.Caption = ”共“ & nnum & ”页 第“ & numpage & ”页“ ElseIf tkbase = ”学生与课程“ Then If numpage > 1 Then numpage = numpage1)= Null Then '空值的处理 Grid2.Cell(i, j).Text = ”“ Else Grid2.Cell(i, j).Text = qy1.Fields(j1)= Null Then '空值的处理 Grid1.Cell(i, j).Text = ”“ Else Grid1.Cell(i, j).Text = qy1.Fields(j1)= Null Then '空值的处理 Grid2.Cell(i, j).Text = ”“ Else Grid2.Cell(i, j).Text = qy1.Fields(j1 If Grid1.Cell(hang, 1).Text = ”“ Then MsgBox ”己完成修改操作!“, , ”提示“ Exit Sub End If sql = ”update “ & tkbase & ” set “

For j = 2 To fnumber1).Name & ”='“ & Grid1.Cell(hang, j).Text & ”',“

Next sql = sql & qy1.Fields(j1 If Grid2.Cell(hang, 1).Text = ”“ Then MsgBox ”己完成修改操作!“, , ”提示“ Exit Sub End If sql = ”update “ & tkbase & ” set “

For j = 2 To fnumber1).Name & ”='“ & Grid2.Cell(hang, j).Text & ”',“

Next sql = sql & qy1.Fields(j1

sql = sql & Grid1.Cell(i, j).Text & ”','“

Next sql = sql & Grid1.Cell(i, fnumber).Text & ”')“ Set qy1 = cnn.Execute(sql)End If Next MsgBox ”命令执行完毕!“, vbInformation, ”完成“ Grid1.Rows = 1 Grid1.Rows = 21 Case ”学生与课程“ MsgBox ”未授权版本,学生与课程的保存代码未执行“ End Select gridsave = False griddelete = False '拒绝删除 gridedit = False

Exit Sub tkFinish:

MsgBox Err.Description End Sub Private Sub XPButton6_Click()On Error GoTo tkFinish MsgBox ”未授权版本,不支持目标删除操作!“, , ”提示“ Exit Sub tkFinish:

MsgBox Err.Description End Sub

Private Sub XPButton8_Click(Index As Integer)Call findcg_Click End Sub

5.4成绩统计表及程序如下:

相关程序代码如下:

Private Sub Form_Load()XPFrame1.Visible = False

Set qy2 = cnn.Execute(”select 班级名称 from 班级“)Do While Not qy2.EOF

Combo1.AddItem qy2.Fields(0)qy2.MoveNext Loop Set qy2 = cnn.Execute(”select 课程名称 from 课程“)Do While Not qy2.EOF

Combo2.AddItem qy2.Fields(0)qy2.MoveNext Loop End Sub

Private Sub XPButton1_Click()If XPRadioButton1.Value = True Then XPFrame1.Visible = False

If Combo1.Text <> ”“ And Combo2.Text <> ”“ Then tbsql1 = ”select 姓名,avg(成绩)as平均成绩,max(成绩)as 最高分,min(成绩)as 最低分 from 学生与课程,学生信息 where 学生与课程.学号=学生与课程.学号 and 学生信息.学号=学生与课程.学号 and 班级='“ & Combo1.Text & ”' and 课程名称='“ & Combo2.Text & ”' Group by 姓名 order by avg(成绩)desc“ tbbm1 = Combo1.Text & Combo2.Text & ” 成绩统计表“ tbsql2 = ”select 成绩 from 学生与课程,学生信息 where 学生与课程.学号=学生信息.学号 and 班级='“ & Combo1.Text & ”' and 课程名称='“ & Combo2.Text & ”'“ ElseIf Combo1.Text <> ”“ Then tbsql1 = ”select 姓名,avg(成绩)as平均成绩,max(成绩)as 最高分,min(成绩)as 最低分 from 学生与课程,学生信息 where 学生与课程.学号=学生与课程.学号 and 学生信息.学号=学生与课程.学号 and 班级='“ & Combo1.Text & ”' Group by 姓名 order by avg(成绩)desc“ tbbm1 = Combo1.Text & ”所有成绩统计表“ tbsql2 = ”select 成绩 from 学生与课程,学生信息 where 学生与课程.学号=学生信息.学号 and 班级='“ & Combo1.Text & ”'“ Else tbsql1 = ”select 姓名,avg(成绩)as平均成绩,max(成绩)as 最高分,min(成绩)as 最低分 from 学生与课程,学生信息 where 学生与课程.学号=学生与课程.学号 and 学生信息.学号=学生与课程.学号 Group by 姓名 order by avg(成绩)desc“ tbbm1 = ”所有学生成绩统计表“ tbsql2 = ”select 成绩 from 学生与课程,学生信息 where 学生与课程.学号=学生信息.学号“ End If Unload Me Form5.Show 1 Else If Combo1.Text <> ”“ Then Class = Combo1.Text tbbm1 = Combo1.Text & ” 成绩统计表“ Else MsgBox ”未选择班级!“ XPFrame1.Visible = False Exit Sub End If Unload Me Form8.Show 1 End If End Sub

登陆界面

成绩查询图表如下:

相关程序代码如下: Private Sub Form_Load()XPFrame1.Visible = False

Set qy2 = cnn.Execute(”select 班级名称 from 班级“)Do While Not qy2.EOF

Combo1.AddItem qy2.Fields(0)qy2.MoveNext Loop Set qy2 = cnn.Execute(”select 课程名称 from 课程“)Do While Not qy2.EOF

Combo2.AddItem qy2.Fields(0)qy2.MoveNext Loop End Sub

Private Sub XPButton1_Click()If XPRadioButton1.Value = True Then XPFrame1.Visible = False

If Combo1.Text <> ”“ And Combo2.Text <> ”“ Then tbsql1 = ”select 姓名,avg(成绩)as平均成绩,max(成绩)as 最高分,min(成绩)as 最低分 from 学生与课程,学生信息 where 学生与课程.学号=学生与课程.学号 and 学生信息.学号=学生与课程.学号 and 班级='“ & Combo1.Text & ”' and 课程名称='“ & Combo2.Text & ”' Group by 姓名 order by avg(成绩)desc“ tbbm1 = Combo1.Text & Combo2.Text & ” 成绩统计表“ tbsql2 = ”select 成绩 from 学生与课程,学生信息 where 学生与课程.学号=学生信息.学号 and 班级='“ & Combo1.Text & ”' and 课程名称='“ & Combo2.Text & ”'“ ElseIf Combo1.Text <> ”“ Then tbsql1 = ”select 姓名,avg(成绩)as平均成绩,max(成绩)as 最高分,min(成绩)as 最低分 from 学生与课程,学生信息 where 学生与课程.学号=学生与课程.学号 and 学生信息.学号=学生与课程.学号 and 班级='“ & Combo1.Text & ”' Group by 姓名 order by avg(成绩)desc“ tbbm1 = Combo1.Text & ”所有成绩统计表“ tbsql2 = ”select 成绩 from 学生与课程,学生信息 where 学生与课程.学号=学生信息.学号 and 班级='“ & Combo1.Text & ”'“ Else tbsql1 = ”select 姓名,avg(成绩)as平均成绩,max(成绩)as 最高分,min(成绩)as 最低分 from 学生与课程,学生信息 where 学生与课程.学号=学生与课程.学号 and 学生信息.学号=学生与课程.学号 Group by 姓名 order by avg(成绩)desc“ tbbm1 = ”所有学生成绩统计表“ tbsql2 = ”select 成绩 from 学生与课程,学生信息 where 学生与课程.学号=学生信息.学号“ End If Unload Me Form5.Show 1 Else If Combo1.Text <> ”“ Then Class = Combo1.Text tbbm1 = Combo1.Text & ” 成绩统计表“ Else MsgBox ”未选择班级!“ XPFrame1.Visible = False Exit Sub End If Unload Me Form8.Show 1 End If End Sub 成绩统计;

Private mblnChanged As Boolean Private Sub Form_Load()On Error GoTo finish Grid1.SetRegisterInformation ”CNwinndy“, ”W]vyY-nonvk-unty-Zbl_e-`hms^“ '进行注册

Dim i As Long

Dim ac1, ac2, ac3, ac4, ac5 As Integer

Grid1.AutoRedraw = False

Grid1.CellBorderColorFixed = vbButtonShadow

Grid1.FixedRowColStyle = Flat

Grid1.Rows = 40

Grid1.Cols = 5

Grid1.RowHeight(1)= 30 For i = 1 To 1 Grid1.Column(i).Width = 70

Next

'设置单元格文字

Grid1.Cell(1, 1).Text = tbbm1 '图表的表名称

Grid1.Cell(2, 1).Text = ”姓 名“

Grid1.Cell(3, 1).Text = ”平均分“

Grid1.Cell(4, 1).Text = ”最高分“

Grid1.Cell(5, 1).Text = ”最低分“

Set qy1 = cnn.Execute(tbsql1)

If qy1.EOF = True Then

MsgBox ”无任何对应数据!“

Exit Sub

End If

Do While Not qy1.EOF

Grid1.Cols = Grid1.Cols + 1

Grid1.Cell(2, Grid1.Cols1).Text = Mid(qy1.Fields(1), 1, 4)

Grid1.Cell(4, Grid1.Cols1).Text = Mid(qy1.Fields(3), 1, 4)

qy1.MoveNext

Loop For i = 1 To Grid1.Cols1).Merge

Grid1.Range(1, 1, 5, 1).Alignment = cellCenterCenter

Grid1.Range(2, 1, 2, Grid1.Cols1).Alignment = cellRightCenter

Grid1.Range(2, 1, 2, Grid1.Cols1)

.Borders(cellEdgeLeft)= cellThin

.Borders(cellEdgeRight)= cellThin

.Borders(cellEdgeTop)= cellThin

.Borders(cellEdgeBottom)= cellThin

.Borders(cellInsideHorizontal)= cellThin

.Borders(cellInsideVertical)= cellThin

End With

'添加一个3D柱形图表,并设置细边框

With Grid1.Range(7, 1, 15, Grid1.Cols1

.ChartType = cell3DColumnClustered

.ScaleFont = False

End With

Set qy2 = cnn.Execute(tbsql2)Dim cg As Double

'对成绩进行图表显示

Do While Not qy2.EOF

cg = qy2.Fields(0)

Select Case cg

Case 90 To 150

ac1 = ac1 + 1

Case 80 To 89

ac2 = ac2 + 1

Case 70 To 79

ac3 = ac3 + 1

Case 60 To 69

ac4 = ac4 + 1

Case 0 To 59

ac5 = ac5 + 1

End Select

qy2.MoveNext Loop

Grid1.Cols = Grid1.Cols + 5

Grid1.Cell(17, 1).Text = ”比例统计“

Grid1.Cell(18, 1).Text = ”优“

Grid1.Cell(18, 2).Text = ”良“

Grid1.Cell(18, 3).Text = ”中“

Grid1.Cell(18, 4).Text = ”及格“

Grid1.Cell(18, 5).Text = ”不及格“

Grid1.Cell(19, 1).Text = ac1

Grid1.Cell(19, 2).Text = ac2

Grid1.Cell(19, 3).Text = ac3

Grid1.Cell(19, 4).Text = ac4

Grid1.Cell(19, 5).Text = ac5

'设置单元格格式

Grid1.Cell(17, 1).Font.Size = 11

Grid1.Range(17, 1, 17, 5).Merge

Grid1.Range(17, 1, 17, 5).Alignment = cellCenterCenter

Grid1.Range(18, 1, 19, 5).Alignment = cellCenterCenter

Grid1.Range(18, 1, 18, 5).BackColor = vbYellow

With Grid1.Range(18, 1, 18, 5)

.Borders(cellEdgeLeft)= cellThin

.Borders(cellEdgeRight)= cellThin

.Borders(cellEdgeTop)= cellThin

.Borders(cellEdgeBottom)= cellThin

.Borders(cellInsideHorizontal)= cellThin

.Borders(cellInsideVertical)= cellThin

End With

'添加一个饼图

With Grid1.Range(22, 1, 32, 5)

.Merge

.Borders(cellEdgeLeft)= cellThin

.Borders(cellEdgeRight)= cellThin

.Borders(cellEdgeTop)= cellThin

.Borders(cellEdgeBottom)= cellThin

End With

Grid1.AddChart 22, 1

With Grid1.Chart(22, 1)

.SetDataSource 18, 1, 19, 5

.ChartType = cell3DPie

.DisplayDataLabels = True

.ScaleFont = False

End With

Grid1.PageSetup.CenterHorizontally = True

'设置打印区域

Grid1.PageSetup.PrintRows = 37

Grid1.PageSetup.PrintColumns = 4

Grid1.AutoRedraw = True

Grid1.Refresh Exit Sub finish:

MsgBox Err.Description 'MsgBox ”无此对象或其它参数错误!" End Sub

Private Sub Form_Resize()If Me.WindowState <> 1 Then

Grid1.Left = 240

Grid1.Width = Me.Width960 End If End Sub

总结

通过近三个月的毕业设计,经过资料的收集、方案的选择比较和论证,到分析计算,再到程序的编制以及毕业设计论文的撰写等各个环节,我对大学三年专科阶段的知识有了一个整体的深层次的理解,同时对程序的理解更加深刻和准确。因此,通过毕业设计实现了预期目标

我由衷的感谢我的指导老师杜涛对我的学习、工作、以及课题的研究和论文撰写过程中面临的问题所给的细心指导和无私帮助感谢和我一起做毕业设计的何爱云 常旭存同学给我的帮主和启迪 使我们正确按时地完成了此次毕业设计的全部内容,也感谢机电工程系教研室全体老师、支持我的其他老师和同学对我的热心帮助。谨向审评本文的各位专家、老师致意!

参 考 文 献

[1].刘新民,蔡琼,白康生编著《Visual Basic 6.0程序设计》清华大学出版社2004

[2].郭胜,夏邦贵编著《Visual Basic数据库开发入门与范例解析》机械工业出版社2004.1

[3].王彬华,李建华编著《Visual Basic实例教程》电子科技大学出版社2004.4

[4].刘韬,骆娟,何旭洪编著《Visual Basic数据库系统开发实例导航(第二版)》人民邮电出版社2003.8

[5].孙越编著《Visual Basic数据库开发自学教程》人民邮电出版社2003.7

[6].郭晓烹编著《Visual Basic高级编程及其项目应用开发》中国水利水电出版社

[7].曹青 郭志强编著的《Visual Basic程序设计教程》机械工业出版社

第二篇:学生信息管理系统

摘 要

随着网络通信技术的迅速发展和信息技术的广泛应用,计算机的应用已普及到经济和社会生活的各个领域。教育领域也不例外,现今已经出现了各种远程网络在线教育系统、图书馆管理系统、学生信息管理系统等。其中学生信息管理是任一院校都不可缺少的部分,它的内容对于学校的决策者和教学管理者来说都至关重要,而传统的人工管理方式效率较低,为数据的查询、更新和维护带来了极大的不便。所以学生信息管理信息系统的开发和应用是必要的,它能够为管理人员提供充足的信息和快捷的查询手段,提高学校对学生信息的管理效率。

本文的学生信息管理系统是基于java语言的,它能够提供学生信息管理功能,方便系统管理员对学生学号、班级等信息的添加、修改、删除、查询等操作,同时可以一样方便的对学生的信息进行查询。本系统也主要利用java语言和access实现,因此它具有很强的可移植性,很方便。

关键字: 学生信息 管理系统

添加 删除 查询 修改

Abstract With the rapid development of network communication technology and extensive application of information technology, computer applications have spread to the economic and social life in various fields.The field of education is no exception, now there have been a variety of remote network online education system, library management system, student information management system.Which is either a student information management schools are an indispensable part of its contents and teaching for school managers, policy-makers are essential, and the traditional manual management inefficient for data query, update and maintenance brought great inconvenience.So the student information management system development and application of information is necessary, it is able to provide managers with sufficient information and quick inquiry means to improve school student information management efficiency.This student information management system is based on the java language, it is able to provide students with information management function to facilitate system administrators to students student number, class and other information to add, modify, delete, query and other operations, but can be just as convenient for students information to search.This system is mainly achieved using java language and access, so it is very portable, very convenient.Keywords: Student Information Management System add delet revise

前言

随着计算机技术的飞速发展,信息时代的到来,信息改变了我们这个社会。学校在管理、教学、办公各个方面也在悄悄地变化。一个学校的信息化程度体现在将计算器与信息技术应用于教学与管理,以现代化工具代替传统手工作业。无疑,使用信息化管理使教学更先进、办公更高效、管理更科学,信息交流更迅速。

学生成绩管理系统是一个教育单位不可缺少的部分,它的内容对于学校的决策者和管理者来说都至关重要,所以学生成绩信息管理系统应该能够为用户提供充足的信息和快捷的查询手段。但一直以来人们使用传统人工的方式管理文件档案,这种管理方式存在着许多缺点,如:效率低、保密性差,另外时间一长,将产生大量的文件和数据,这对于查找、更新和维护都带来了不少的困难。

作为计算机应用的一部分,使用计算机对学生成绩信息进行管理,具有着手工管理所无法比拟的优点.例如:检索迅速、查找方便、可靠性高、存储量大、保密性好、寿命长、成本低等。这些优点能够极大地提高学生档案管理的效率,也是企业的科学化、正规化管理,与世界接轨的重要条件。

因此,开发这样一套管理软件成为很有必要的事情,故决定选择学生成绩管理系统来作为本人的毕业设计,在很短的时间里开发出一套界面友好,功能强大,使用简单的适用于各规模学院的学生成绩管理系统。该学生成绩管理系统能有效的处理在校学生的成绩管理,具有成绩输入、成绩查询、成绩统计及打印功能。

学生成绩管理系统可以实施应用在各中、大、小院校中,适用范围很广,应用性强。随着系统实施的日益成熟,最终会使单机作业为主的教学管理活动提高到这个平台上来,从而实现学校学生成绩信息管理的办公自动化,籍以提高办学效率和质量。使学校充分利用计算机所带来的新技术,为培养人才打下坚实的基础。

第一章 相关技术简介

1.1 java语言简介

Java语言是sun公司与1995年5月正式发布的程序设计语言,他的前身是sun公司为智能消费类家用电器研究而开发的项目的一部分。

Java程序设计语言是新一代语言的代表,他强调了面向对象的特性,可以用来开发范围广泛的软件,它具有支持图形化的用户界面,网格以及数据库连接等复杂功能。Java语言的主要特点: 1)易于学习

Java语言很简单,对于熟悉C++的程序设计人员更不会对其感到陌生,因 为它的语法非常接近于C++,但他同时摒弃了C++许多的复杂易混淆的功能。利用java同样可以变质出非常复杂的系统,且运行占用很少的内存资源。2)高效率的执行方式

Java语言的执行方式是采用先经过编译器编译,在通过解释器解释执行的 方式来运行的。他综合了解释性语言与编译语言的众多有点,使其执行效率较以往的程序设计语言有了大幅度的提高。3)与平台的无关性

由于iava语言是解释执行的,他会被转换成一种字节码的“目标程序”。因此它可以跨平台运行 4)分布式安全性

Java从诞生之日起就与网络联系在了一起,他强调网络特性,内置TCPIP,HTTP,FTP协议库,便于开发网上应用系统。5)丰富的API文档和类库

Java为用户提供了详尽的API(Application Program Interface)文档说明。

1.2 access数据库简介

Microsoft Office Access是微软把数据库引擎的图形用户界面和软件开发工具结合在一起的一个数据库管理。他拥有逻辑、流程处理,即VBA语言(VB也可以用来做逻辑处理);又可以存储数据,即在“表”中存储数据。

第二章 系统分析

2.1 系统分析

学生信息管理系统,可用于学校等机构的学生信息管理,查询,更新与维护,使用方便,易用性强,图形界面清晰明了。该软件用java语言编写,用access数据库作为后台的数据库进行信息的存储,用SQL语句完成学生学籍信息的添加,查询,修改,删除的操作以及成绩的录入,修改,删除等。用ODBC驱动实现前台Java与后台SQL数据库的连接。Java语言跨平台性强,可以在windows,linux,ubuntu等系统下使用,方便简单,安全性好。

本《学生管理系统》具有对学生进行学籍管理的功能。并于数据库相连接,能够对学生的学号、姓名、性别、班级、专业进行查询、添加和删除等,简捷方便,容易使用。2.2 应解决的问题

2.2.1合理的设计数据库

尽量合理地减少数据库数据的冗余,使重复的数据保持在最小限度,这样将不必要的多占用存储空间,减少产生混乱影响的危险,还能提高计算机的运行速度。作为学生成绩管理系统,必须能解决以下方面的问题:能录入信息。

在开发学生信息管理系统时,最重要的就是学生的基本信息,其学生信息表E-R图如图2.1所示。

图 2.1 学生信息E-R图

2.2.2设计出友好的界面

界面的友好与否是用户评价一个软件优劣的重要方面。因为该系统涉及到

学生成绩的真实性,所以该系统要具有一定的保密性和权限控制,首先应设计一个用户的登陆窗口界面,要求只能由特定的人员对该系统进行操作。此外还应设计登陆后系统的主窗口,要求能够显示学生成绩的基本信息,可以实现数据的录入,更新,删除、查询、统计等功能。

另外窗口界面要多用按钮,少用菜单,窗口的各个控键布局要合理,美观。要充分的利用java.awt和java.swing提供的强大的功能,多用窗口和控件,充分体现窗口的多元化格局。

2.2.3实现的基本功能

该系统要求除了能实现信息的录入,删除,插入,更新,数据导出excel文件等基本功能之外,还要求能够根据用户的需要进行操作。例如要查询学生成绩,要求可以按照专业、班级等多种方式查询。这些功能基本上能满足用户操作的需要,这样用户操作起来就更简单方便。部分文本框使用了下拉式,使用户可以不用花费大量的时间去输入信息。

2.3 数据库物理设计 1.1.1 3.3.1数据库物理设计

本系统采用Access数据库管理系统作为后台数据库的开发工具,设计的表结构如下:

第三章 程序代码及运行效果

3.1主类代码:

/*主类代码*/ package kcsj;import java.awt.*;import javax.swing.*;import java.awt.event.*;

import javax.swing.border.*;import javax.swing.JOptionPane;import javax.swing.JLabel;import javax.swing.JPanel;import javax.swing.table.DefaultTableCellRenderer;import javax.swing.table.DefaultTableModel;import javax.swing.table.TableColumn;import java.sql.*;import java.awt.GridLayout;public class myStudent { public myStudent(){

}

public static void main(String[] args){ // TODO code application logic here loginFrame lf=new loginFrame();Font ft=new Font(“Serif”,Font.BOLD,18);lf.setVisible(true);lf.addWindowListener(new WindowAdapter(){ public void windowClosing(WindowEvent e){

System.exit(0);} });} }

3.2 登陆: public loginFrame(){

p=new JPanel();

user=new JTextField(10);

pass=new JPasswordField(10);

login=new JButton(“登录”);

cancel=new JButton(“退出”);

p.setBackground(Color.lightGray);

//user.setText(“王明玉”);

//pass.setText(“123456”);

login.addActionListener(this);

cancel.addActionListener(this);

p.add(new JLabel(“学生信息管理系统登录”));

p.add(new JLabel(“账号:”));

p.add(user);

p.add(new JLabel(“密码:”));

p.add(pass);

p.add(login);

p.add(cancel);

this.add(p);

this.setTitle(“学生管理系统登录界面”);

this.setSize(180,160);}

public void actionPerformed(ActionEvent e){

//查找

if(e.getSource()==login){

if(user.getText().toString().equals(“")){

JOptionPane.showMessageDialog(null, ”请输入用户名“, ”温馨提示“, JOptionPane.INFORMATION_MESSAGE);

}else if(pass.getText().toString().equals(”“)){

JOptionPane.showMessageDialog(null, ”请输入密码“, ”温馨提示“, JOptionPane.INFORMATION_MESSAGE);

}else{

myConnection conn=new myConnection();

ResultSet rs;

String sql=”select * from admin where 用户名 = '“+user.getText().toString()+”' and 密码 = '“+pass.getText().toString()+”'“;

try{

rs=conn.getResult(sql);

if(rs.next()){

this.dispose();

//JOptionPane.showMessageDialog(null, ”此用户已经存在“, ”温馨提示“, JOptionPane.INFORMATION_MESSAGE);

sql=”select * from student“;

mainFrame mf=new mainFrame();

mf.setTitle(”西北师范大学学生信息管理系统“);

mf.setSize(600,486);

mf.freshTable(sql);

mf.setVisible(true);

mf.addWindowListener(new WindowAdapter(){

public void windowClosing(WindowEvent e){

System.exit(0);

}

});

}else{

JOptionPane.showMessageDialog(null, ”用户名或密码错误“, ”登录失败“, JOptionPane.INFORMATION_MESSAGE);

}

}catch(Exception er){

System.out.println(er.toString());

}

}

//全部显示

}if(e.getSource()==cancel){

System.exit(0);

} } } 登陆界面:

3.3 修改数据:

/*修改数据*/ class editFrame extends JDialog implements ActionListener{ public static final int WIDTH = 400;public static final int HEIGHT = 400;

JLabel 学号1,姓名1,性别1,民族1,年龄1,年级1,班级1,专业1;JTextField 学号,姓名,性别,民族,年龄,年级,班级,专业;JButton b;JPanel p;

mainFrame mf;

public editFrame(mainFrame mmf){ setTitle(”修改学生信息“);setSize(WIDTH,HEIGHT);setLocation(120,180);

Container contentPane = getContentPane();contentPane.setLayout(new FlowLayout());

学号1=new JLabel(”学号“);姓名1=new JLabel(”姓名“);性别1=new JLabel(”性别“);民族1=new JLabel(”民族“);年龄1=new JLabel(”年龄“);年级1=new JLabel(”年级“);班级1=new JLabel(”班级“);

专业1=new JLabel(”专业“);

学号=new JTextField(5);姓名=new JTextField(5);性别=new JTextField(5);民族=new JTextField(5);年龄=new JTextField(5);年级=new JTextField(5);班级=new JTextField(10);专业=new JTextField(10);学号.setEnabled(false);b=new JButton(”确定“);p=new JPanel();p.setLayout(new GridLayout(10,2,5,5));p.add(学号1);p.add(学号);p.add(姓名1);p.add(姓名);p.add(性别1);p.add(性别);p.add(民族1);p.add(民族);p.add(年龄1);p.add(年龄);p.add(年级1);p.add(年级);p.add(班级1);p.add(班级);p.add(专业1);p.add(专业);p.add(new Label(”“));p.add(new Label(”“));p.add(b);contentPane.add(p);//添加按钮监听器

b.addActionListener(this);mf=mmf;}

public void actionPerformed(ActionEvent e){

if(学号.getText().toString().equals(”“)){

JOptionPane.showMessageDialog(null,”请输入学号“,”温馨提示“, JOptionPane.INFORMATION_MESSAGE);

}else if(姓名.getText().toString().equals(”“)){

JOptionPane.showMessageDialog(null,”请输入姓名“,”温馨提示“, JOptionPane.INFORMATION_MESSAGE);

}else if(年龄.getText().toString().equals(”“)){

JOptionPane.showMessageDialog(null,”请输入年龄“,”温馨提示“, JOptionPane.INFORMATION_MESSAGE);

}else{

String sql=”update student set 姓名='“+姓名.getText()+”',性别='“+性别.getText()+”',年龄=“+年龄.getText()+”,年级='“+年级.getText()+”',班级='“+班级.getText()+”',专业='“+专业.getText()+”',民族='“+民族.getText()+”' where 学号='“ + 学号.getText()+ ”'“;

myConnection conn=new myConnection();

try{

//JOptionPane.showMessageDialog(null, sql, ”温馨提示“, JOptionPane.INFORMATION_MESSAGE);

if(conn.executeSql(sql)){

JOptionPane.showMessageDialog(null, ”修改成功“, ”温馨提示“, JOptionPane.INFORMATION_MESSAGE);

mf.freshTable(”select * from student“);

this.dispose();

}else{

JOptionPane.showMessageDialog(null, ”修改失败“, ”温馨提示“, JOptionPane.INFORMATION_MESSAGE);

}

}catch(Exception er){

System.out.println(er.toString());

}

}

}

}

3.4 查找数据:

class findFrame extends JDialog implements ActionListener{

mainFrame mf;JPanel p;JComboBox c;JTextField t;JButton b;JButton fAll;String sql=”select * from student“;String[] colStr={”学号“,”姓名“,”性别“,”民族“,”年龄“,”年级“,”班级“,”专业“};

public findFrame(mainFrame mmf){

mf=mmf;

p=new JPanel();

c=new JComboBox(colStr);

t=new JTextField(10);

b=new JButton(”查找“);

fAll=new JButton(”全部显示“);

b.addActionListener(this);

fAll.addActionListener(this);

p.add(new JLabel(”选择“));

p.add(c);

p.add(new JLabel(”查找内容“));

p.add(t);

p.add(b);

p.add(fAll);

this.add(p);

this.setTitle(”查找“);

this.setSize(450,80);}

public void actionPerformed(ActionEvent e){

//查找

if(e.getSource()==b){

String selectStr=c.getSelectedItem().toString();

if(selectStr==”年龄“){

sql=”select * from student where “+selectStr+” “+t.getText().toString();

}

else {

sql=”select * from student where “+selectStr+” '“+t.getText().toString()+”'“;

= = 12

}

mf.freshTable(sql);

//全部显示

}if(e.getSource()==fAll){

sql=”select * from student“;

mf.freshTable(sql);

} } }

3.5 添加数据:

class addFrame extends JDialog implements ActionListener{ public static final int WIDTH = 400;public static final int HEIGHT = 400;

JLabel 学号1,姓名1,性别1,民族1,年龄1,年级1,班级1,专业1;JTextField 学号,姓名,性别,民族,年龄,年级,班级,专业;JButton b;JPanel p;

mainFrame mf;

public addFrame(mainFrame mmf){ setTitle(”修改学生信息“);setSize(WIDTH,HEIGHT);setLocation(120,180);

Container contentPane = getContentPane();//contentPane.setBackground(Color.BLACK);//设置窗口颜色

contentPane.setLayout(new FlowLayout());

学号1=new JLabel(”学号“);

姓名1=new JLabel(”姓名“);

性别1=new JLabel(”性别“);

民族1=new JLabel(”民族“);

年龄1=new JLabel(”年龄“);

年级1=new JLabel(”年级“);

班级1=new JLabel(”班级“);

专业1=new JLabel(”专业“);

学号=new JTextField(”201071030240“,5);

姓名=new JTextField(5);

性别=new JTextField(”女“,5);

民族=new JTextField(5);

年龄=new JTextField(5);

年级=new JTextField(5);

班级=new JTextField(10);

专业=new JTextField(10);

b=new JButton(”确定“);p=new JPanel();p.setLayout(new GridLayout(10,2,5,5));p.add(学号1);p.add(学号);p.add(姓名1);p.add(姓名);p.add(性别1);p.add(性别);p.add(民族1);p.add(民族);p.add(年龄1);p.add(年龄);p.add(年级1);p.add(年级);p.add(班级1);p.add(班级);p.add(专业1);p.add(专业);p.add(new Label(”“));p.add(new Label(”“));p.add(b);contentPane.add(p);//添加按钮监听器

b.addActionListener(this);mf=mmf;}

public void actionPerformed(ActionEvent e){

if(学号.getText().toString().equals(”“)){

JOptionPane.showMessageDialog(null, ”请输入学号“, ”温馨提示“, JOptionPane.INFORMATION_MESSAGE);

}else if(姓名.getText().toString().equals(”“)){

JOptionPane.showMessageDialog(null, ”请输入姓名“, ”温馨提示“, JOptionPane.INFORMATION_MESSAGE);

}else if(年龄.getText().toString().equals(”“)){

JOptionPane.showMessageDialog(null, ”请输入年龄“, ”温馨提示“, JOptionPane.INFORMATION_MESSAGE);

}else{

String sql=”select * from student where 学号='“ + 学号.getText()+ ”'“;

myConnection conn=new myConnection();

ResultSet rs;

rs=conn.getResult(sql);

try{

//System.out.println(rs.getRow());

if(rs.next()){

JOptionPane.showMessageDialog(null, ”此学号已经存在“, ”温馨提示“, JOptionPane.INFORMATION_MESSAGE);

}else{

sql=”insert into student values('“ +学号.getText()+”','“+ 姓名.getText()+”','“+ 性别.getText()+”','“+ 民族.getText()+”',“+ 年龄.getText()+”,'“+ 年级.getText()+”','“+ 班级.getText()+”','“+ 专业.getText()+”')“;

if(conn.executeSql(sql)){

JOptionPane.showMessageDialog(null, ”添加成功“, ”温馨提示“, JOptionPane.INFORMATION_MESSAGE);

mf.freshTable(”select * from student“);

学号.setText(”“);

姓名.setText(”“);

性别.setText(”“);

民族.setText(”“);

年龄.setText(”“);

年级.setText(”“);

班级.setText(”“);

专业.setText(”“);

}else{

JOptionPane.showMessageDialog(null, ”添加失败“, ”温馨提示“, JOptionPane.INFORMATION_MESSAGE);

}

}

}catch(Exception er){

System.out.println(er.toString());

}

}

}

}

3.6 修改数据:

class editFrame extends JDialog implements ActionListener{ public static final int WIDTH = 400;public static final int HEIGHT = 400;

JLabel 学号1,姓名1,性别1,民族1,年龄1,年级1,班级1,专业1;JTextField 学号,姓名,性别,民族,年龄,年级,班级,专业;JButton b;JPanel p;

mainFrame mf;

public editFrame(mainFrame mmf){ setTitle(”修改学生信息“);setSize(WIDTH,HEIGHT);setLocation(120,180);

Container contentPane = getContentPane();contentPane.setLayout(new FlowLayout());

学号1=new JLabel(”学号“);

姓名1=new JLabel(”姓名“);

性别1=new JLabel(”性别“);

民族1=new JLabel(”民族“);

年龄1=new JLabel(”年龄“);

年级1=new JLabel(”年级“);

班级1=new JLabel(”班级“);

专业1=new JLabel(”专业“);

学号=new JTextField(5);

姓名=new JTextField(5);

性别=new JTextField(5);

民族=new JTextField(5);

年龄=new JTextField(5);

年级=new JTextField(5);

班级=new JTextField(10);

专业=new JTextField(10);

学号.setEnabled(false);

b=new JButton(”确定“);p=new JPanel();p.setLayout(new GridLayout(10,2,5,5));p.add(学号1);p.add(学号);

p.add(姓名1);p.add(姓名);p.add(性别1);p.add(性别);p.add(民族1);p.add(民族);p.add(年龄1);p.add(年龄);p.add(年级1);p.add(年级);p.add(班级1);p.add(班级);p.add(专业1);p.add(专业);p.add(new Label(”“));p.add(new Label(”“));p.add(b);contentPane.add(p);//添加按钮监听器

b.addActionListener(this);mf=mmf;}

public void actionPerformed(ActionEvent e){

if(学号.getText().toString().equals(”“)){

JOptionPane.showMessageDialog(null, ”请输入学号“, ”温馨提示“, JOptionPane.INFORMATION_MESSAGE);

}else if(姓名.getText().toString().equals(”“)){

JOptionPane.showMessageDialog(null, ”请输入姓名“, ”温馨提示“, JOptionPane.INFORMATION_MESSAGE);

}else if(年龄.getText().toString().equals(”“)){

JOptionPane.showMessageDialog(null, ”请输入年龄“, ”温馨提示“, JOptionPane.INFORMATION_MESSAGE);

}else{

String sql=”update student set 姓名='“+姓名.getText()+”',性别='“+性别.getText()+”',年龄=“+年龄.getText()+”,年级='“+年级.getText()+”',班级='“+班级.getText()+”',专业='“+专业.getText()+”',民族='“+民族.getText()+”' where 学号='“ + 学号.getText()+ ”'“;

myConnection conn=new myConnection();

try{

//JOptionPane.showMessageDialog(null, sql, ”温馨提示“, JOptionPane.INFORMATION_MESSAGE);

if(conn.executeSql(sql)){

JOptionPane.showMessageDialog(null, ”修改成功“, ”温馨提示“, JOptionPane.INFORMATION_MESSAGE);

mf.freshTable(”select * from student“);

this.dispose();

}else{

JOptionPane.showMessageDialog(null, ”修改失败“, ”温馨提示", JOptionPane.INFORMATION_MESSAGE);

}

}catch(Exception er){

System.out.println(er.toString());

}

} } }

运行效果:

第四章 总结

通过本次课程设计,不仅让我更深入的了解JAVA这门学科,更使自己有了继续探索的兴趣。

对我来说,在之前的学习过程中没有能够很好的掌握JAVA语言的学习,在很多地方还有生疏和遗漏,并且在此次课程设计过程中也遇到困难不能自己独立解决。但是,通过这次程序设计,除了增加了自己的编程能力,提高了我对JAVA的应用能力,同时我也深感“认真严谨”这个词的重要性,一点点小的马虎,便会导致整个程序不能正常运行。在今后的学习中,我将继续保持严谨的学习态度。与此同时,在同学的帮助下,让我体会到了相互学习的重要性,而更让人难以忘怀的是在热烈讨论问题时,那激情横溢的场面。总之,此次课程设计让我获益匪浅。

第五章 总结

课程设计是培养学生综合运用所学知识,发现,提出,分析和解决实际问题,锻炼实践能力的重要环节,是对学生实际工作能力的具体训练和考察过程.本次课程设计虽然很辛苦,实在是受益匪浅。本来这门课的知识学的就不够扎实,本次课程设计,在设计过程中碰到了很多问题,刚开始要设计的时候,还真不知道从哪里下手但最终在图书、同学和老师的帮助下都得到了解决,让我学会了好多书本上没有的东西,通过本次课程设计我也能将课本上的知识融会贯通,起到了很好的辅助学习的效果,但是我发现我学到的知识比整整一个学期学到的都多。理

论和实践的相结合是学习最有效的方法。在设计的过程中发现了自己的不足之处,对以前所学过的知识理解得不够深刻,掌握得不够牢固,通过这次课程设计之后,一定把以前所学过的知识重新温故。

通过这次课程设计使我懂得了理论与实际相结合是很重要的,只有理论知识是远远不够的,只有把所学的理论知识与实践相结合起来,从理论中得出结论,才能真正为社会服务,从而提高自己的实际动手能力和独立思考的能力。

第六章 参考文献

第三篇:学生信息管理系统

–––––––––––––––––摘 要–––––––––––––––––

学生信息管理系统是典型的信息管理系统(MIS),其开发主要包括后台数据库的建立和维护以及前端应用程序的开发两个方面。对于前者要求建立起数据一致性和完整性强、数据安全性好的库。而对于后者则要求应用程序功能完备,易使用等特点。

经过分析,我们使用MICROSOFT公司的VISUAL BASIC开发工具,利用其提供的各种面向对象的开发工具,尤其是数据窗口这一能方便而简洁操纵数据库的智能化对象,首先在短时间内建立系统应用原型,然后,对初始原型系统进行需求迭代,不断修正和改进,直到形成用户满意的可行系统。

关键字:控件、窗体、域、数据库。

–––––––––––––––––前言–––––––––––––––––

随着学校的规模不断扩大,学生数量急剧增加,有关学生的各种信息量也成倍增长。面对庞大的信息量需要有学生管理系统来提高学生管理工作的效率。通过这样的系统可以做到信息的规范管理、科学统计和快速查询、修改、增加、删除等,从而减少管理方面的工作量。

本系统主要用于学校学生信息管理,总体任务是实现学生信息关系的系统化、规范化和自动化,其主要任务是用计算机对学生各种信息进行日常管理,如查询、修改、增加、删除,另外还考虑到学生选课,针对这些要求设计了学生信息管理系统本系统主要用于学校学生信息管理,总体任务是实现学生信息关系的系统化、规范化和自动化,其主要任务是用计算机对学生各种信息进行日常管理,如查询、修改、增加、删除,另外还考虑到学生选课,针对这些要求设计了学生信息管理系统。

本系统主要包括学生信息查询、教务信息维护和学生选课三部分。其功能主要有: ⒈有关学籍等信息的输入,包括输入学生基本信息、所在班级、所学课程和成绩等。⒉学生信息的查询,包括查询学生基本信息、所在班级、已学课程和成绩等。⒊学生信息的修改。

⒋班级管理信息的输入,包括输入班级设置、年级信息等。⒌班级管理信息的查询。⒍班级管理信息的修改。⒎学生课程的设置和修改。

目 录

前言

第一章 Visual Basic 概述 1.1 Visual Basic 语言的特点

1.2 Visual Basic 系统几个程序应用中的常用名词 第二章 Windows 下的Visual Basic 编程环境简介 2.1 面对对象的编程 2.2 实现菜单选项 2.3 实现工具栏

第三章 怎样开发一个学生信息管理系统的查询模块 3.1 学生信息系统的设计分析 3.2 编程环境的选择 3.3 关系型数据库的实现 3.4 二者的结合(DBA)第四章 使用Access2000 创建数据库 4.1 数据库的概念 4.2 新建一个数据库 4.3 修改已建的数据库 第五章 可行性分析 第六章 系统总体规划 6.1 系统功能 6.2 系统流程图 第七章 系统具体实现 7.1 各功能的实现 7.1.1 课程管理 7.1.2 打印统计 结束语 后记 主要参考文献

第一章 Visual Basic 概述 1.1 Visual Basic 语言的特点

Visual Basic 语言用其设计应用程序时具有两个基本特点:可视化设计和事件驱动编程。(1)可视化设计:表现在VB在设计应用于程序界面时有“所见即所得”的处理功能。(2)事件驱动编程:在设计应用程序时,把对象添加到窗体中,在用户与程序进行交互时,用户基本上是通过鼠标、键盘与应用程序进行交互的,那些对象就必须对鼠标和键盘操作所引发的事件做出响应,来执行一段应用程序。1.2 Visual Basic 系统几个在程序应用中的常用名词

Visual Basic 系统除了一般高级语言所具有的一些名词术语外,还有几个系统常用的名词。其基本含义如下:(1)视窗(Form)

视窗是进行人机交互的界面或接口,也叫窗体。VB系统的人机交互界面或接口,无论是在设计时或是在运行时,都是Windows 系统的标准视窗。(2)对象(Object)

对象是VB系统内部提供给设计者可以直接使用的处理输出的控制工具。本程序所应用到的对象类型有标签框(Label Box),文本框(Text Box),命令按扭(Command Button),网格(Data Grid),ADO控件(Adodc1)等。当把这些工具放置到用户界面对应的窗体上时,被称为对象或控件。用户可以通过设置对象的“属性”和“方法”,便于对象适应自己所设计应用程序的输入输出内容,对象的生成过程及结构都被封装起来。正确使用对象可以减少程序和开发时间,提高程序设计者的工作效率。(3)属性(Properties)

属性是VB系统提供的有关对象的参数或数据接口。用户通过适当地设置或改变对象的属性来确定对象的外观及性能特征,从而有效地使用系统提供的对象。比如,对象的名称、在屏幕上显示的位置、大小、颜色、接收或容纳的数据内容及数据的表现格式等。(4)事件(Events)

事件是指用户或操作者对计算机进行的某一操作(如击键、单击或移动鼠标等)的行为或系统状态发生的变化。VB系统常用事件来引导计算机执行一段程序。程序所用的键盘事件有KeyPress(按键)事件,KeyDown事件和KeyUp事件;鼠标事件有Click(单击鼠标)事件,DbDlicd(双击鼠标)。(5)方法(Method)方法主要是指对一个对象使用某种作用的过程。它是在程序执行的过程中要计算机执行的某种操作。其程序的方法有Show(显示)方法,Hide(隐藏)方法,Refresh(刷新)方法。

(6)过程(Procedure)

过程是指经过定义或说明的,或基于某一对象对应的事件所引发的程序段。(7)模块(Module)

模块是指一些运算量或过程进行声明或定义的一个集合。系统程序大体可分成四个模块:数据输入、根据查询、数据打印和通讯。

第二章 Windows下的Visual Basic 编程环境简介 2.1 面对对象的编程

面向对象的设计方法(OOP, Objected Programming)从应用领域内的问题着手,以直观自然的方式描述客观世界的实体。Visual Basic 作为一种面向对象的编程方法,把程序和数据封装起来作为一个对象,并为每个对象赋予相应的属性。在设计对象时,不必编写建立和描述每个对象的程序代码,而是用工具画在界面上,由 Visual Basic 自动生成对象的程序代码并封装起来。Visual Basic 应用程序基本的构建块是用户所创建的对象,每一个对象都具有一些特性和行为(属性、事件和方法)。开发人员可以最有效利用所创建的每一个对象。使用应用程序具有可通用性可说扩展性和强有力的功能。

Visual Basic 应用由一系列对象组成,包括有函数、菜单、函数、结构和数据窗口、用户对象、用户事件等等,对象中又包含若干控件如命令按钮、单行编辑器等这些对象和控件都可在许多应用中重复使用。2.2 实现菜单选项

菜单是程序最重要的特性之一,大多数程序都依赖一个定义良好的菜单使程序易于使用和维护,Visual Basic 也提供了强大的创建菜单功能是程序更加标准。

本系统使用 Visual Basic 的菜单编辑器建立菜单或者修改已经存在的菜单,您也可以使用Visual Basic 的Application Wizard 来操作。2.3 实现工具栏

CoolBar控件与Office2000 中看到的CoolBar是类似的。CoolBar就是一个可以在窗体上浮动的工具,同时也是其他ActiveX的容器。通过在CoolBar中迁入其他空间你也可以向用户提供更好的灵活性和义用性。

选择“工程”下拉菜单中的“部件”选项,显示“部件”对话框。在“控件”选项卡列表中选择“Microsoft Windows Common Controls 6.0”后工具相中增加改控件。本系统就用了Cool工具中的Statubar控件,在系统这一界面中,添加了状态栏,在第一个栏中,在样式这一栏中选择了文本,在第二个栏中,选择了系统日期,第三个栏中选择了系统时间,这样,任何时候操作本系统,都可以看到当前的时间和日期。

第三章 怎样开发一个学生信息管理系统的查询模块? 3.1查询模块的设计分析

根据实际情况,我们使用原型法(Rapid Prototyping)即以少量代价快速地构造一个可执行的软件模型。使用户可以较快地确定需求,然后采用循环进化的开发方式,对系统模型作连续的精化,将系统需具备的性质逐渐增加上去,直到所有的性质全部满足。此时模块也发展成为最终产品了。3.2编程环境的选择

微软公司的Visual Basic 6.0是Windows应用程序开发工具,使目前最为广泛的、易学易用的面向对象的开发工具。Visual Basic提供了大量的控件,这些控件可用于设计界面和实现各种功能,减少了编程人员的工作量,也简化了界面设计过程,从而有效的提高了应

用程序的运行效率和可靠性。故而,实现本系统VB是一个相对较好的选择。3.3关系型数据库的实现

Access2000就是关系数据库开发工具,数据库能汇集各种信息以供查询、存储和检索。Access的优点在于它能使用数据表示图或自定义窗体收集信息。数据表示图提供了一种类似于Excel的电子表格,可以使数据库一目了然。另外,Access允许创建自定义报表用于打印或输出数据库中的信息。Access也提供了数据存储库,可以使用桌面数据库文件把数据库文件置于网络文件服务器,与其他用户共享数据库。Access 是一种关系数据库工具,关系数据库是已开发的最通用的数据库之一。如上所述,Access作为关系数据库开发具备了许多优点,可以在一个数据包同时拥有桌面数据库的便利和关系数据库的强大功能。3.4二者的结合(DBA)微软的JET数据库引擎提供了与数据库打交道的途径,我们是通过它以及Visual Basic来访问数据库并对其进行各种操作。Visual Basic、Access以及其他微软的软件产品都是通过共用JET数据库引擎,从而给用户提供了丰富的数据类型。ADODC控件在数据库中的信息与将信息显示给用户看的Visual Basic 程序之间架起了一座桥梁。我们可以设置ADODC控件的各个属性,告诉它要调用那个数据库的哪个部分。缺省情况下,ADODC控件根据数据库中的一个或多个数据库表建立一个dynaset-type(动态集合)类型的记录集合。一个记录集合是动态的也就意味着,当原来的数据表中的容改变了以后,该记录集合中的记录也会随之改变。将ADODC控件放置在窗体中之后,我们还必须在该控件与要处理的数据库之间建立联系。

第四章 使用Access2000创建数据库 4.1数据库的概念

数据库是一种存储数据并对数据进行操作的工具。数据库的作用在于组织和表达信息,简而言之,数据库就是信息的集合。计算机的数据库可以分为两类:非关系数据库(flat-file)和关系数据库(relational)。关系数据库中包含了多个数据表的信息,数据库含有各个不同部分的术语,象记录、域等。4.2新建一个数据库

创建任何一个数据库的第一步是仔细的规划数据库,设计必须是灵活的、有逻辑的。创建一个数据库结构的过程被认为是数据模型设计。1. 标识需要的数据;

2. 收集被子标识的字段到表中; 3. 标识主关键字字段; 4. 规范数据;

5. 标识指定字段的信息;

4.3修改已建的数据库

数据库的修改分为;添加、编辑和删除记录。这三种操作均可由Visual Basic创建的程序来完成,下面的章节将详细描述实现的具体方法。

第五章 可行性分析

学生信息,作为一个学校,就有一定的工作量存在,而学生信息,它的工作量可能是其它信息工作量的几倍,班级的增加、班级的查找、班级的修改;学生档案;课程管理;成绩管理;缴费管理;统计等等,每个信息的数据都在不断地变化着,如果采用人工的方式进行操作,那么,一天的工作量,足以让人觉得比较繁琐,吃不消。针对这样的情况,采用让数据的查询变得简单化,数据变的更让每个人都在任何时刻都可以了解到。学生信息管理系统是为本校开发的,本系统所采用的语言是Visual Basic,用Microsoft Access 2000数据库完成。该系统总体有四部分组成,包括学生信息查询、教务信息维护、学生选课及用户管理。通过本系统,把本校内部查询学生信息、教务信息、学生选课各个环节进行有效地计划、组织和控制。通过本校内部的信息,依据统一数据信息进行管理,把任何一块信息所产生的数据变动及时地反映给其它相关信息,做到数据共享。本系统主要信息流程为:教务信息维护接受学生的信息,学生信息查询根据教务信息维护的学生信息做出对所接收的信息合理性进行判断,并交于信息维护进行相应的修改,再把信息存入数据库中。学生选课是对学生进行相应选择自己相关的课程。最后进行打印。采用本系统,能够使整个系统内部所有信息的工作简化,提高工作效益。由于采用统一的数据信息,使相关资料能够快速地查询所需的数据、资料及其它信息的,使信息快速高效运行。

本系统中使用到的数据表主要有班级表、成绩表、缴费表、课程表、学生档案、用户资料,由这六个表,组成了名为信息的数据库(如图一)。其中学生档案是本系统主要的(图一)

一张表,所有信息都是根据这张学生档案进行有关的操作,主要的字段有:学号、姓名、年级、专业、性别、出生年月、民族、籍贯、政治面貌、家庭地址、邮政编码、联系电话、入学时间、备注。其中日期的数据类型为日期/时间天型,其它的数据类型为文本型;成绩表中字段为:学号、姓名、年级、专业、学期、考试时间、考试科目、考试地点、课程性质、科目分数、违纪类型、备注;课程表中字段为:专业、年级、学期、课程名称、教材、任课老师、课时、上课地点、课程性质、考试性质;用户资料中的字段包括:用户名、密码、身份。

数据库与VB的连接:本系统的数据链接采用的是ADO方法,打开控制面板,打开ODBC数据源图标,选择“系统DSN”标签,点击“添加”按钮,在弹出的“创建新数据源”对话框中选择名称为“Microsoft Access Drive(*.mdb)”,点击“完成”按钮,在ODBC Microsoft Access 安装对话框中在数据源名中输入信息,在数据库这个框中,单击“选择”按钮,在弹出的选择数据库这一对话框架中,在驱动器下拉列表框中选择本系统数据库所在驱动器,在目录中选择库所在的文件夹,在文件类型中选择选“Access数据库(*.mdb)”,在数据库名中选择本系统的数据库,点击“确定”按钮即完成数据链接。

在VB中,用ADODC链接数据库,用DataGrid或DATA将库中的数据在界面中显示出来,本系统采用DataGrid。在界面上右击Adodc控制,在弹出的快捷菜单中选择属性,在属性对话框中,在“属性”这一标签中,选中单选框“Use ODBC Data Source Name”,并在下拉文本框中选择已经配置好的数据源名信息,再在“RecordSoure”标签中,在Commard Text(SQL)文本框中输入查询语句,如:select * from 学生档案。同时,将桌面的DataGrid控件选中,在属性框中,将它的Datasoure设为Adodc。我们可以设置DataGrid控件的外观:选中该控件,右击,在弹出的快捷菜单中选择“检索字段”,在弹出的对话框中单击“确定”,这时,表格中出现了表的字段。然后再右击,同样,在弹出的快捷菜单中选择“编辑”,我们就可以所在的表格的宽度进行调整。

第六章 系统(查询模块)总体规划 6.1系统功能(查询模块)1. 查询信息的情况; 2. 判断信息是否符合要求; 3. 将符合条件的信息进行打印; 6.2流程图

学生注册 基本信息输入 学籍信息管理 班级管理 班级课程设置 课程基本信息 班级课程管理 成绩信息输入 成绩信息管理 班级设置

第七章 系统具体实现 7.1各功能的实现

7.1.1课程管理:课程设置(如:界面如图二)(图二)

运行程序后,进入课程管理模块,课程管理模块的第一块是课程设置,在这模块中可以把专业、年级、学期、课程名称、教材、任课老师、课时、上课地点、课程性质和考试性质等信息输入,以便使用。结束语 学生信息管理系统(课程设置和打印统计)的完成,它在审核这一功能中能够对不同情况的资料进行设置和打印,针对需要的信息进行设置和打印。

后记

本系统能够顺利完成,非常感谢指导老师陈志卫老师,同时,也感谢和我一起合作完成本系统的另两位同学。对于本人来说,通过这次毕业设计,也是对自己在这三年学习的一个检验和平时学习的一种结累,可以在学习中提高自己,也充分体现学有所用,学以致用的学习倡导。

在此,我对三年来辅导过我的各位任课老师深表感谢

主要参考文献

本系统的过程中,主要的参考文献有:

《Visual Basic6.0》 林陈雷 人民邮电出版社 《面向对象程序设计系列教材》 龚沛曾 高等教育出版社 《Visual Basic6.0编程实例精解》 何文俊

《学用Visual Basic 编程》 潭 浩 西安电子科技大学出版社 《Visual Basic6.0 数据库开发与专业应用》 敬 铮 国防工业出版社 《Visual Basic6.0 数据库程序设计高手》 温贤发 科学出版社

第四篇:学生信息管理系统

目 录

摘要

随着电脑的普及与使用,现在的管理也提升了一个档次,渐渐实现了无纸化办公,即从原来的人工记录管理模式转变为电脑一体化管理。高校是科研的阵地,后勤的学生信息管理系统也应该一改传统的人工管理,更加信息化,时代化,节省人力物力,提高效率。基于这一点,我设计了学生信息管理系统的方案。

学生信息管理系统,是以高校的管理方式为实例而设计的一种实用型管理系统。本系统最大的特点是通用性、简单操作性,适用于同行业以及一些同类型的企业管理。随着学校寄宿人员的增多,学生信息管理系统人员的负担越来越重,为了让所有学生信息管理系统人员能从繁重的工作中解脱出来,实现无纸化办公;使工作更有条理,更方便,更有效率而开发出这套学生信息管理系统软件。

关键词:信息、管理、实用性、高校

前言

从2012年3月27日开始,我们进行了为期一周的软件工程课程设计选题工作。在这一周我确定了我的课程设计题目:学生信息管理系统。

确定设计题目之后,我先做了一些准备工作,借阅必要的书籍与材料,通过互联网以及其他媒介收索了关于学生信息管理系统的相关知识,然后进行针对性的学习。首先就是开发此类项目的背景。当前,学生信息管理体制相对比较落后。主要表现在以下几个方面:1.高校现行的管理体制不能完全适应国有的管理发展的需要。2.信息管理人员超编现象普遍存在。

3、高校的信息管理大多数都还停留在初级的计算机管理上。对于大量的数据和庞大的数据结构,简单的用EXCEL表格来记录是远远无法满足信息的规模的。必须实行现代化信息管理,定制专业的信息管理软件来进行相关的管理。

4、学生信息公开化不够。高校的精密仪器设备一般都比较贵重,学生的信息如不能得到有效的共享,将会严重制约设备的使用效率,甚至导致重复购买。一套完整的网络系统将会让这个问题迎刃而解。

在需求分析阶段,我对学生信息管理系统进行了系统功能分析。系统功能包括登陆、学生查询自己的信息、管理员的日常管理、教师的登陆、查询等几部分。

接着在系统设计和详细设计阶段期间,因为需要自学和探索的内容与软件较多,所以我发挥积极主动精神投入课程设计和开发活动。除了老师正式安排的课程设计时间之外,还充分利用课余时间,向善长这方面的同学进行请教和互相探讨,力争获得最大收益。在需求分析的基础上,考虑经济、技术和运行环境等各方面条件,确定系统的总体结构和系统各组成部分的技术方案,合理选择计算机和通信的软硬件设备,提出系统的实施计划。内容主要包括学生学校管理系统总体结构设计、系统流程设计等等。根据系统的逻辑模型,完成数据流程图等的设计。使我对这些开发设计的软件应用工具运用和掌握的更加熟练。

员。每个人都有唯一的一个用户名,每个用户名都有与之对应的密码,如果用户名和密码不一致,则无法登陆主界面。如果用户输入错误可以单击“重臵”按钮,重新输入。输入完整单击“确定”按钮进入主界面。

图1:登陆界面

2.2.2 主界面用例描述

用户通过下拉列表框选择身份,可以是学生、教师或者管理员。用户选择身份以后,输入自己的用户名和密码。系统通过认证后,出现学生信息管理系统主界面。通过系统验证用户进入学生信息管理主界面,在主界面中我们可以看到登陆学生的基本信息,学生所修课程的信息。用户可以通过“查找”按钮看到所查找学生的信息。如图2:

图2:主界面

2.2.3 修改密码用例描述

登陆到主界面中,我们可以看到在主界面的右侧

图3:修改密码界面

2.2.4 选修课信息用例描述

用户单击“选修课信息”按钮,进入到选修课信息界面。在选修课信息界面中我们可以看到本学期所有可选的课程信息。学生选择选修课程表的课程,在界面的左下角会出现对应的课程详细信息。单击“选修”,就可将所选课程添加到列表框里。单击“退选”按钮,那么已选课程将从所选课程列表里删除,同时退选课程里将出现退选的课程,单击退选就可以退选此课程了。单击“确定”按钮,保存选修课信息。用户还可以通过“查看”按钮查看历年来的所选修的课程情况。如图4所示:

图4:选修课信息

2.2.5 个人信息用例描述

在主界面的学生基本信息框下面有两个按钮,一个是“查看更多信息”一个是“修改基本信息”。学生、教师、管理员都可以在主界面单击“查看更多信息”按钮,进入“个人信息”界面里查看个人基本的信息。管理员可以对这些进行修改,并且只限管理员修改。如图5。

图5:个人信息界面

2.2.6 修改学生信息用例描述

管理员可以单击修改按钮对学生信息进行修改,当用户是学生或者老师时,修改按钮对其不可用。

管理员进入个人信息界面时,单击修改按钮就可以进入到修改个人信息界面,对学生的信息进行修改。单击“确定”按钮保存。如图6:

图6:修改个人信息界面

2.2.7 查看、修改课程信息用例描述

在主界面中我们还可以看到学生所修课程信息情况。这里列出了本学期该学生所修的所有具体课程,每个具体课程占一行,单击“具体课程信息”按钮进入

“课程信息”界面,用户可以看到完整的课程号、课程名、授课教师、学分信息。同时可以通过选择不同学年的时间段来查看相应学年的课程信息。如图7:

教师和管理员有权对课程信息进行修改,如果要修改学生课程信息可以单击“修改”按钮,进入到“修改课程信息”界面,这里列出可课程名、课程号、任课教师等一系列与课程有关的信息。单击“确定”可以保存修改的信息并退出。如图8:

图7:查看课程信息界面

图8:修改课程信息

2.2.8 考勤表用例描述

在主界面上单击“考勤信息”进入到“考勤表”的界面。系统给出所查找学生的考勤情况。其中包括住宿考勤与课堂考勤两部分。并且最上方有学生的住宿信息以及基本信息。如图9所示:

图九:考勤表信息界面

2.2.9 奖惩表用例描述

在主界面,单击“奖惩信息”按钮。进入奖惩表界面,这里给出了历年的奖励与惩罚信息以及学生的基本信息。如果单击“修改”按钮可以对学生奖惩项进行添加、删除、修改等操作,此操作只能由管理员进行。学生信息管理系统给出相应的学生的奖惩情况。学生单击个人信息界面上的“奖惩”按钮,进入到奖惩表的界面。教师在查找到相应的学生信息后可以通过“奖惩”按钮来查看该生所有的奖励与惩罚项。如图10:

图10:奖惩表信息界面

2.2.10 修改奖惩信息用例描述

管理员可以通过“修改”按钮进入到“修改奖惩信息”界面。可以对学生的奖惩信息直接进行修改。如图11:

图11:修改奖惩信息界面

3.2.2 修改密码时序图

用户进入主界面,单击“修改密码”按钮进入“修改密码”界面。输入相应的修改信息,系统检测输入是否完整、确认密码是否与新密码一致、旧密码是否正确。检测通过,显示成功信息。如图二所示:

图2:修改密码时序图

3.2.3 选修课信息时序图

学生在主界面单击“选修课信息”进入选修课信息界面,此界面上显示了所有可选的课程信息,这些信息来自选修课信息表。单击某一课程,在详细课程信息里显示具体课程信息,课程的具体信息来自模板课程信息表。如图三所示:

图3:选修课信息时序图

3.2.4 退选选修课时序图

当学生选修了某一课程时,该课程也许与该生课时或其他原因有所冲突而不能选修,这时应有提示,并让该生退选改课程。学生单击“退选”按钮,系统提示是否退选,单击“是”则在学生的选修课信息表里移除这个选课项。如图四所示:

图4:退选选修课时序图

3.2.5 查看基本信息时序图

学生进入主界面后,主界面显示了学生的个人信息,单击“查看更多信息”按钮,进入“个人信息界面”,此界面中显示的信息来自学生的基本信息表。如图五所示:

图5:查看基本信息时序图

3.2.6 修改个人信息时序图

在个人信息界面中单击“修改”按钮,进入到修改学生信息界面,修改界面的学生信息也是来自学生的基本信息表,当用户单击修改时,系统提示是否修改,单击“是”,系统修改基本信息项。并保存。如图六所示:

图6:修改个人信息时序图

3.2.7 课程信息时序图

用户进入主界面,单击“具体课程信息”按钮,进入到课程信息界面。在这里显示了具体的课程信息。此信息来自个人课程信息表。如图七所示:

图7:课程信息时序图

3.2.8 修改课程信息时序图

管理员或者教师在课程信息界面单击“修改”按钮或者从主界面单击“修改课程信息”按钮,进入到修改课程信息界面,当用户单击修改时,系统检测信息是否完整,并提示是否修改,单击“是”,系统这时修改个人课程信息表的信息项。如图八所示:

图8:修改课程信息时序图

3.2.9 考勤表时序图

用户在主界面单击“考勤信息”进入考勤表界面。在考勤表界面中显示学生的出勤信息。此信息来自学生的住宿考勤表和课件考勤表。如图九所示:

图9:考勤表时序图

3.2.10 奖惩表时序图

用户在主界面单击“奖惩信息”进入奖惩表界面,此界面显示该生所有的奖惩情况。这些信息来自于学生的奖惩表。如图十所示:

图10:奖惩表时序图

3.2.11 修改奖惩表信息时序图

当管理员单击修改时,进入修改奖惩信息界面,这里显示的信息同样来自奖惩表。当单击“修改”时,系统检测信息是否完整,提示是否修改,单击“是”,系统修改奖惩信息项,并提示修改成功。如图十一:

图11:修改奖惩信息时序图

总结

从3月27日开始,我们进行了将近三个月的课程设计。通过这次课程设计,我拓宽了知识面,锻炼了能力,综合素质得到较大提高。安排课程设计的基本目的,在于通过理论与实际的结合、人与人的沟通,进一步提高思想觉悟。尤其是观察、分析和解决问题的实际工作能力,以便培养成为能够主动适应社会主义现代化建设需要的高素质的复合型人才。作为整个学习体系的有机组成部分,课程设计虽然安排在了三个月的时间进行,但并不具有绝对独立的意义。它的一个重要功能,在于运用学习成果,检验学习成果。运用学习成果,把课堂上学到的系统化的理论知识,尝试性地应用于实际设计工作,并从理论的高度对设计工作的现代化提出一些有针对性的建议和设想。检验学习成果,看一看课堂学习与实际工作到底有多大距离,并通过综合分析,找出学习中存在的不足,以便为完善学习计划,改变学习内容与方法提供实践依据。在一个星期的课程设计之后,我们普遍感到不仅实际动手能力有所提高,更重要的是通过对软件开发流程的了解,进一步激发了我们对专业知识的兴趣,并能够结合实际存在的问题在专业领域内进行更深入的学习。

在这次设计中遇到了很多实际性的问题,在实际设计中才发现,书本上理论性的东西与在实际运用中的还是有一定的出入的,所以有些问题不但要深入地理解,而且要不断地更正以前的错误思维。一切问题必须要靠自己一点一滴的解决,而在解决的过程当中你会发现自己在飞速的提升。对于学生信息管理系统,主要是解决程序设计中的问题,而程序设计是一个很灵活的东西,它反映了你解决问题的逻辑思维和创新能力,它才是一个设计的灵魂所在。因此在整个设计过程中大部分时间是用在程序上面的。很多子程序是可以借鉴书本上的,但怎样衔接各个子程序才是关键的问题所在,这需要对系统的结构很熟悉。因此可以说系统的设计是软件和硬件的结合,二者是密不可分的。通过这次课程设计我也发现了自身存在的不足之处,虽然感觉理论上已经掌握,但在运用到实践的过程中仍有意想不到的困惑,经过一番努力才得以解决。

我觉得作为一名学习软件工程的学生,这次课程设计是很有意义的。更重要的是如何把自己平时所学的东西应用到实际中。虽然自己对于这门课懂的并不

多,很多基础的东西都还没有很好的掌握,觉得很难,也没有很有效的办法通过自身去理解,但是靠着这三个月的“学习”,在老师、同学的帮助和讲解下,渐渐对这门课逐渐产生了些许的兴趣,自己开始主动学习并逐步从基础慢慢开始弄懂它。同时,在这里感谢我们的指导老师彭博老师的悉心解惑和指导。

第五篇:学生信息管理系统

学生信息管理系统论文

2010-04-01清华领导力培训诺贝尔论文网 在传统模式下利用人工进行学生信息管理系统论文,存在着较多缺点,如:效率底,保密性差,时间一长将产生大量文件和数据,更不便于查找,更新,维护等。诸如这些情况,学校管理者对学生信息管理系统论文带来很大困难,严重影响教育工作者的工作效率。

一、引言

学生信息管理系统(Student Information Management System),以下简称SIMS,是针对学校人事处的大量业务处理工作而开发的管理软件,是典型的管理信息系统。它是一个教育单位不可缺少的部分,它的内容对于学校的决策者和管理者来说都至关重要,它能够为用户提供充足的信息和快捷的查询手段。能有效的帮助学校和老师掌握学生的情况,为学生提供成绩跟课程方面的查询。在传统模式下利用人工进行学生信息管理系统论文,存在着较多的缺点,如:效率底,保密性差,时间一长将产生大量的文件和数据,更不便于查找,更新,维护等。诸如这些情况,令学校管理者对学生信息管理系统论文带来了很大困难,严重影响了教育工作者的工作效率。

随着科学技术的不断提高,计算机科学日渐成熟,使用日趋成熟的计算机技术来代替传统的人工模式,来实现学生信息的现代化管理,其强大的功能已为人们深刻认识,它已进入人类社会的各个领域并发挥着越来越重要的作用。作为计算机应用的一部分,使用计算机对学生信息进行管理,具有着手工管理所无法比拟的优点.例如:检索迅速、查找方便、易修改、可靠性高、存储量大、数据处理快捷、保密性好、寿命长、成本低、便于打印等。这些优点能够极大地提高学生信息管理系统论文的效率,也是学校的科学化、正规化管理,与世界接轨的重要条件。用计算机制作的学生信息管理系统论文还可以通过功能强大的Internet网及时的向学生的家长传递该生在校的最新成绩,有助于学校与家长的信息互动,为更好地把握学校的教育方针起到了一定的促进作用!因此,开发这样一套管理软件成为很有必要的事情。

二、管理信息系统

(一)概述

管理信息系统(Management Information System,简称MIS)是一个由管理人员和计算机组成的用以进行信息的收集、传输、加工、存储、维护和使用的系统。它是一门综合了管理科学,系统理论,计算机科学的系统性边缘科学。

管理信息系统的物理组成:

1.计算机硬件系统:包括主机、外部存储器、输入输出设备等。

2.计算机软件系统:包括系统软件和应用软件两大部分。

3.通信系统:包括线路等通信设施和与计算机网络、数据通信有关的软件等。

4.工作人员:包括系统分析员、程序设计员、维护人员、管理员、操作人员等。

(二)管理信息系统的发展

管理信息系统通过对企业当前运行的数据进行处理来获得有关信息,以控制企业的行为;利用过去和现在的数据及相应的模型,对未来的发展进行预测;能从全局目标出发,对企业的信息管理thldl.org.cn决策活动予以辅助。从工业发达国家来看,管理信息系统的发展经历了以下几个阶段:

第一阶段:(1953年至1965年)单项数据处理阶段,也称电子数据处理(EDP)阶段。这是电子计算机在管理领域应用的起步阶段。这一阶段,由于当时计算机硬、软件的限制,数据处理的性质只是使用计算机代替人的手工劳动,进行简单的单项数据处理工作,如计算工资、数据统计、报表登记、编制计划等。这个阶段的处理方式主要是集中式的批处理。

第二阶段:(1965年至1970年)综合数据处理阶段,也称事务处理系统(TPS)阶段。这个阶段计算机硬、软件有了很大的发展,出现了多用户的分时系统,计算机开始应用于对某一个管理子系统的控制,并具有一定的反馈功能。如库存管理系统、生产调度系统、物资管理系统等。这个阶段的处理方式已发展为面向终端的联机实时处理。

第三阶段:(1970年至今)管理信息系统(MIS)阶段。这个阶段是在企业中全面的使用计算机把各种管理子系统的功能集中起来,构成了计算机化的全方位的信息系统,即现代管理信息系统。这个阶段的处理方式是在数据库和网络基础上组成分布式处理系统。它的特点是使用数据库和分时处理的计算机网络,并充分利用运筹学等数学方法,实现了硬件、软件和数据资源的共享。

三、学生信息管理系统

信息管理系统论文主要功能:学籍信息管理,班级信息管理,课程信息管理,成绩信息管理,用户信息管理。具体系统功能需求描述如下:

(一)学籍信息管理

每年的大量新生入学,老生毕业都需要处理大量的信息管理系统论文。通过这一模块,可以实现学生基本情况的添加、删除、更新。还能查询各个学生的情况,姓名、家庭电话、家庭住址、学号等各个消息

(二)班级信息管理

实现班级的添加、删除、更新。查询班级的所在系别,辅导员等。

(三)课程信息管理

每个学期都会增加一些新的科目,通过本模块可以轻松的添加以及更新课程。可以根据学期条件或者班级条件的选择,也可根据课程名、课程号或者班级的选择,并对值的输入,可以看到数据集中显示符合条件的课程数据信息,而且可以根据教工的修改要求进行数据的添加、删除、修改的操作。

该项管理对课程的属性进行了具体化的分类,比如可以分辨是考试科还是考察课,而且根据条件的选择大大得提高了对各学期课程数据的记录操作,很大得帮助了教工们工作效率的提高。

(四)成绩信息管理

本模块实现了成绩的输入、删除、更新。还能查询到平均成绩以及单科最高最低成绩以及个人成绩。把成绩统计这个繁琐的工作简单化,为学生成绩的管理方面提高工作效率。

(五)用户信息管理

因为本信息管理系统论文是供多人一起使用的,必须对某一些人进行限制。于是设置了管理员,非管理员只能进行查询操作,不能进行更改。

四、学生信息管理系统论文开发的意义

(一)计算机信息管理系统论文已经成为我们学习和工作的得力助手:

今天,计算机的价格已经十分低廉,性能却有了长足的进步。它已经被应用于许多领域,计算机之所以如此流行的原因主要有以下几个方面:

首先,计算机可以代替人工进行许多繁杂的劳动;

其次,计算机可以节省许多资源;

第三,计算机可以大大的提高人们的工作效率;

第四,计算机可以使敏感文档更加安全,等等。

(二)开发学生信息管理系统论文的意义

SIMS主要是提供学生,老师或者来访者方便的查询等相关操作,对学生的信息管理能统一规范化。功能块的相应操作分别由其对应的子模块实现。通过教育网络或互联网把整个学校的学生信息汇聚起来,为学校教育主管部门提供全面及时的学生信息,方便管理,同时亦可通过校园网扩展各类信息化应用,共享学生信息。学校可通过一个简化的学生信息管理系统,使学生信息管理系统论文工作系统化,规范化,自动化,从而达到提高学生信息管理效率的目的。

五、信息管理系统论文实际调查

(一)国内外现状研究:

计算机在管理中的应用开始于1954年,当时美国首先用计算机处理工资单。40多年来,计算机在处理管理信息方面发展迅速。例如,60年代美国计算机在管理中应用项目不到300项,到了1975年达到2670项。而现在,美国在财务会计上90%的工作由计算机完成;物资管理中80—100%的信息处理由计算机完成;计划管理中是80—90%。据计算机应用方面发展较快的国家统计,计算机用于经济管理的约占80%;用于科技运算的占8%;用于生产过程控制的占12%。我国在全国范围内推广计算机在管理中的应用,是在70年代末开始的,虽然起步较晚,近几年发展却较快,特别是微型计算机的出现和普及为信息处理提供了物美价廉的手段,对于推动我国管理信息处理的现代化起了重要的作用。

(二)目前存在的问题:

传统纸媒介管理的信息管理系统论文难于共享汇总,其统计数据正确性也难以考证。存在着较多的缺点,如:效率底,保密性差,时间一长将产生大量的文件和数据,更不便于查找,更新,维护等。计算机在全国普及后,管理媒介有了质的飞跃。

随着学校的规模不断扩大,学生数量急剧增加,有关学生的各种信息量也成倍增长。面对庞大的信息量,就需要有学生信息管理系统来提高学生管理工作的效率。通过这样的系统,可以做到信息的规范管理、科学统计和快速的查询,从而减少管理方面的工作量。由于计算机和网络的普及,若建立一个C/S或B/S结构的学生信息管理系统,学生便可以通过网络来选课并且查询自己的有关信息,使得学生信息管理工作系统化,规范化,自动化,大大提高了学校管理学生的效率。

六、信息管理系统论文解决方法

该项目开发的软件为学校学生信息管理系统软件,是鉴于目前学校学生人数剧增,学生信息呈爆炸性增长的前提下,学校对学生信息管理的自动化与准确化的要求日益强烈的背景下构思出来的,该软件设计完成后可用于所有教育单位(包括学校,学院等等)的学生信息的管理。

(一)理论支持

当前计算机管理界所流行且实用的系统建设三原则:整体性原则、分作—协调原则、目标优化原则。

1.系统开发的结构化生命周期法。

其基本思想是把整个系统开发过程分成若干个阶段,每个阶段进行若干活动,每项活动应用一系列标准、规范、方法和技术,完成一个或多个任务,形成符合给定规范的产品。

采用结构化生命周期法开发管理信息系统时,应遵循的主要原则:

(1)用户参与的原则;(2)“先逻辑后物理”的原则;(3)“自顶向下”的原则;(4)工作成果描述(主要指文档)标准化的原则。

其具体开发步骤可分为以下四步:系统规划,系统开发(包括系统分析,系统设计,系统实施),系统的运行及维护,系统评价。

2.原型法。

其基本思想是在系统开发的初期,尽快构造出系统的原型,使用户能及早地运行这个系统原型,通过使用它、熟悉它,受到启发并取得经验,然后对系统的目标和功能提出更精确、具体的要求,研制人员据此逐渐修改和完善原型,使它满足用户的需求,最后完成系统的开发。该方法大大提高了系统开发效率,弥补了结构化生命周期法开发时间长的缺陷。通常采用原型法需以下四个阶段:1).明确用户的基本要求,2).研制系统的原型,3).使用、评价系统原型,4).修改和完善原型。

(二)系统设计

系统设计阶段的主要目的是将系统分析阶段所提出的反映了用户信息需求的系统逻辑方案转换成可以实施的基于计算机与通信系统的物理(技术)方案。包括总体结构设计、总体功能设计、总体物理结构设计、系统详细设计、数据库设计(概念结构设计、逻辑结构设计、物理结构设计)、代码设计、输入输出设计等。

(三)硬件环境

硬件配置要求:

CPU:PII333以上。

内存:64MB以上。

硬盘:2.1GB以上(可用空间最好在160MB以上)。

(四)软件环境

1.设计平台: VB6.0

VB是一个面向对象设计的应用程序语言,是开发数据库前端的优秀工具,它的编程语言简洁明快、组件功能强大和编程环境灵活方便。采用VB来开发数据库应用程序具有更大的灵活性和可扩展性。

2.数据库: Microsoft Access

Access 是关系数据库开发工具,数据库能汇集各种信息以供查询、存储和检索。Access 的优点在于它能使用数据表示图或自定义窗体收集信息。数据表示图提供了一种类似于 Excel 的电子表格,可以使数据库一目了然。另外,Access 允许创建自定义报表用于打印或输出数据库中的信息。Access也提供了数据存储库,可以使用桌面数据库文件把数据库文件置于网络文件服务器,与其他网络用户共享数据库。Access 是一种关系数据库工具,关系数据库是已开发的最通用的数据库之一。Access 多用于中小型企业来设计中小型数据库,一般的学校教务系统的数据库用Access 来设计完全能达到要求。由于考虑到本系统是应用在单机系统上,只建立起一个数据库。

3.数据库访问方式:ADO

ADO(Active Data Objects)实际是一种提供访问各种数据类型 的连接机制。ADO设计为一种极简单的格式,通过ODBC的方法同数据库接口。可以使用任何一种ODBC数据源,即不止适合于SQL Server、Oracle、Access 等数据库应用程序,也适合于Excel表格、文本文件、图形文件和无格式的数据文件。ADO是基于OLE-DB之上的技术,因此ADO通过其内部的属性和方法提供统一的数据访问接口方法。其主要优点是易于使用、高速度、低内存支出和占用磁盘空间较少。

七、信息管理系统论文结论

学生信息管理系统是学校信息管理系统论文的一个重要组成部分。他为其他系统(如学校图书管理系统、学校档案管理系统、教学管理系统、总务后勤管理系统等)提供学生的基本信息,同时它也需要如教学管理系统提供课程设置数据等。这些系统在具体应用中构成一个大系统,相互调用对方的数据。

由以上分析,我们可以充分认识到设计并开发一个学生信息管理系统论文的必要性和迫切性,本次设计和开

发的学生信息管理系统应符合学校学生信息管理的规定,满足对学校学生信息管理的需要,并达到操作过程中的直观,方便,实用,安全等要求。系统采用模块化程序设计的方法,既便于系统功能的组合和修改,又便于未参与系统开发的技术维护人员补充和维护。SIMS通过教育网络或互联网把整个学校的学生信息汇聚起来,为学校教育主管部门提供全面及时的学生信息,方便管理,同时亦可通过校园网扩展各类信息化应用,共享学生信息。

下载学生信息管理系统(5篇材料)word格式文档
下载学生信息管理系统(5篇材料).doc
将本文档下载到自己电脑,方便修改和收藏,请勿使用迅雷等下载。
点此处下载文档

文档为doc格式


声明:本文内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:645879355@qq.com 进行举报,并提供相关证据,工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。

相关范文推荐

    学生信息管理系统5篇

    学生管理信息系统 随着学校规模的不断扩大,学生数量的不断增加,学生的信息量也成倍增长。学生管理工作是学校各项工作的一个重要部分,其管理水平的高低将直接影响到人才的培养......

    学生信息管理系统论文

    学生信息管理系统论文 2010-04-01 清华领导力培训诺贝尔论文网 在传统模式下利用人工进行学生信息管理系统论文,存在着较多缺点,如:效率底,保密性差,时间一长将产生大量文件和数......

    VB学生信息管理系统

    学生信息管理系统 前 言 学生籍管理系统是一个教育单位不可缺少的部分,它的内容对于学校的决策者和管理者来说都至关重要,所以学生学生信息管理系统应该能够为用户提供充足......

    学生信息管理系统毕业论文

    ``````Q ASP.NET学生信息管理系统毕业论文 摘 要    随着信息技术在管理上越来越深入而广泛的应用,管理信息系统的实施在技术上已逐步成熟。管理信息系统是一个不断发展......

    学生信息管理系统任务书

    毕业设计(论文)任务书题目学生信息管理系统设计专业软件技术学号 **************姓名 ***主要内容: 当今学校不断扩招,学生人数不断增加,对学生信息的管理必须受到重视。随着计算......

    学生成绩信息管理系统

    武汉理工大学工程硕士课程论文─《面向对象程序设计》 成绩管理系统 zhai 要 随着Internet的发展,管理软件在各行各业得到重用。学生管理系统是一个教育单位不可缺少的部分,它......

    学生信息管理系统源代码

    学生信息管理系统源代码 import java.io.*; class StuInfo { public String name; public int number; public String sex; public String age; public String bir; public......

    学生信息管理系统实验报告

    重庆科创职业学院实 训 报 告题目: 学生信息系统管理专业:计算机信息管理班级:计信管ZB421201学号:2012701287姓名:胡航成绩:指导教师:廖 小 娟完成日期:年月日第一章前言1.1 历史现......