管理信息系统设计说明

上传人:x**** 文档编号:72615051 上传时间:2022-04-09 格式:DOC 页数:37 大小:9.84MB
返回 下载 相关 举报
管理信息系统设计说明_第1页
第1页 / 共37页
管理信息系统设计说明_第2页
第2页 / 共37页
管理信息系统设计说明_第3页
第3页 / 共37页
点击查看更多>>
资源描述
第9章学生管理信息系统随着学校规模的不断扩大,学生数量的不断增加,学生的信息量也成倍增长。学生管理工作是学校各项工作的一个重要部分,其管理水平的高低将直接影响到人才的培养质量。面对庞大的信息量,如何有效地提高学生管理工作的效率是一个学校急需解决的问题。因此开发适合学校需要的学生管理信息系统,通过这样的系统,可以做到信息的规管理、科学统计和快速查询,并减少管理方面的工作量。9.1概述学生管理信息系统作为学校管理中的一个子系统,与其他子系统,如教学管理系统、人事管理系统、后勤管理系统,图书馆管理系统等一起构成构园管理信息系统,为校园管理信息化提供一个子功能。所以,几乎所有的大、中、小学校都需要一套这样的管理系统来提高日常的工作效率。图1和图2所示是两个典型的学生管理信息系统的界面。图1第一个典型的学生管理信息系统的界面 图2第二个典型的学生管理信息系统的界面从界面可以看到,学生管理信息系统应该包括学生信息管理、学籍管理、成绩管理、奖惩管理和系统管理等基本容。(1)学生信息管理的数据有:学生学号、性别、出生日期、所属班级、所属院系、籍贯等,当有新生到校时,就启动相应的信息管理功能,对所有的学生信息进行入库,随时掌握学生的基本信息。(2)学籍管理主要是对学生的学籍变更情况与时控制和管理,变更的原因有:转系、休学、复学、退学和毕业离校。(3)成绩管理是数据量比较大的管理工作,每次考试结束后负责对学生各个科目的成绩入库工作和对数据库成绩出错的校对工作。(4)奖惩管理是针对学生在校的表现情况,对学生进行相应的处理工作,奖励的项目有各种奖学金和文体奖励,处罚的项目有通报批评、警告、严重警告、记过、留校查看、开除等。(5)系统管理主要是执行数据库备份和恢复、数据库表的维护等工作,保证系统的正常运行。学生管理信息系统作为典型的数据库项目应用的一种,其开发流程包括需求分析、UML系统建模、确定系统集成方案、数据库分析和设计以与各功以模块的开发等。下面介绍一个学生管理信息系统的详细开发过程。9.2需求分析需求分析是数据库系统开发的第一步,也是最重要的一步。需求分析可以分为两个过程:一是理解需求,二是分析需求。下面分别分析这两个过程。9.2.1理解需求只有通过对学生管理信息系统的终端用户和客户进行大量的调研,才能真正理解终端用户和客户的需求,才能开发出合理的、实用的管理系统,才能满足各大、中、小学校的管理需要。基于大量的调研数据,下面列出对最典型、最关键的需求。(1)每年开学时,新生来报琶,要对每位新生的信息建立个人档案,这部分工作由学籍科的管理人员进行维护和操作。学生个人档案包括学生学号、性别、出生日期、所属班级、所属院系、籍贯等。(2)考试结束时,教务科的管理人员将学生各科的成绩录入数据库,以备随时查询。当然录入成绩也有出错的可能,所以,必须具有校对修改成绩的功能。(3)当学生的表现出色或差的时候,学生科的管理人员应对其进行奖励或处罚,相应的奖项(或处罚)和奖励(或处罚)时间的数据都应该入库。(4)当学生因为疾病、学业修完等原因学籍需要变更的时候,学籍科的管理人员应该对其进行学籍变更手续。(5)学生应该具有查询个人信息和成绩的权力和权限。(6)系统还应提供强大的数据统计、查询、报表生成以与打印等功能。(7)系统客户端运行在Windows平台下,服务器端可以运行在Windows平台或者Unix平台下。(8)系统应该有很好的可扩展性。在本系统中主要提供新生信息录入、学籍变更、成绩管理和奖惩管理等相关的功能。9.2.2分析需求分析需求就是描述系统的需求,通过定义系统中的关键域类来建立模型。分析的根本目的是在开发者和提出需求的人之间建立一种理解和沟通的机制,因此学生管理信息系统的需求分析是开发人员和学校管理人员一起完成的。分析需求的第一步是描述学生管理信息系统的功能,即定义用例,以此确定系统的功能需求。一所学校的主要成员就是学生和学校的管理人员、教师、系统管理员等,管理人员主要指学籍科、学生科和教务科的人员,他们是学生管理信息系统的主要使用者。学生也是学生管理信息系统的重要使用者,只是具备的管理权限没有管理人员那么广。系统管理员也是其中一个管理人员,这不影响本系统的功能。学生管理信息系统的用例包括以下容。新生信息学生成绩(包括录入和校对)学籍变更学生奖励学生处罚学生信息查询修改需要注意的是,学生信息查询修改用例包括学生对个人基本信息和查询和修改,这些信息指的是新生入学时被录入的基本信息。此外,学生还具有查询和打印成绩的权限,查询奖惩情况、学籍变更记录等权限。学生管理信息系统的分析可以用UML的用例图来描述。每个用例还可以以文本的方式描述,描述的容包括用例以与用例与角色交互的更详细的信息,文本的容是通过和用户讨论后确定的。下面给出上述用例的描述。(1)新世界生信息增加学生记录标记学生学号确定学生院系确定学生班级(2)学生成绩增加学生成绩记录校对学生成绩(3)学籍变更增加学籍变更记录标记变更原因标记变更时间(4)学生奖励增加学生奖励记录标记奖励项目标记奖励时间(5)学生处罚增加学生处罚记录标记处罚等级标记处罚时间(6)学生信息查询修改查询个人信息修改个人信息保存个人信息查询奖惩情况查询学籍变更情况打印成绩单9.3UML系统建模完成需求分析后,就需要对系统进行UML建模。UML建模是对需求分析结果的模型建立过程。下面进行学生管理信息系统的UML建模过程。9.3.1学生管理信息系统的用例分析在上一节需求分析中列出了学生管理信息系统的全部用例:新生信息、学生成绩、学籍变更、学生奖励、学生处罚、学生信息查询修改。这里,使用权用Rose软件进行UML建模,其用例如图3所示。图3学生管理信息系统用例图该用例图标记了所有的学生管理住处系统的用例,从中可以得知,学生管理信息系统的角色可以划分为两类。学校管理人员:用例包括学生管理信息系统的所有用例。学生:用例只有学生信息查询修改。要注意的是,学校管理人员具有查询和修改所有数据的权限,处于高权限位置,而学生只有修改个有基本信息、查询奖惩情况、查询学籍变更情况和打印成绩单的权限,处于低权限位置。9.3.2学生管理信息系统的域类分析UML建模的第二步就是域类分析。实际开发学生管理信息系统时,域类分析是建立在用例分析基础上的。要了解系统要处理的概念,最好奖学校的管理人员组织起来开个讨论会,详细谈论和列举所需要包含水量的用例,了解概念和概念之间的关系。学生管理信息系统中的域主要包括:学生(Student)、成绩(Score)、学籍变更(Change)、奖励(Encourage)、处罚(Punish)。可以在类图中将上面这些域以与它们之间的关系表示出来,如图4所示。图4学生管理信息系统域草图需要说明的是,这里的域类还是处于“草图”状态,定义的操作和属性不是最后的片本,只是 在现阶段看来这些操作和属性是比较合适的,有些操作奖在时序图的草图中定义,而不晨用例哪定义。有些类可以用UML状态图来显示类的对象的不同状态以与改变状态的事件。在本系统中有状态图的类是学生,该类的状态图将在后面的容中介绍。为了描述域类的动态行为,可以使用权UML的时序图、协作图或者活动图来描述。本文选用时序图。时序图的基础是用例。在时序图中要说明域类是如何协作以操作该系统中的用例。当然,在建立时序图时,将会发现新的操作,并将其加入类中,这将在后面看到所建立的时序图模型。用时序图建模时,需要窗口或对话框作为角色界面。显然,这里需要操作界面的有基本信息、奖励、处罚、学籍变更、修改查询等,此外维护也需要一个操作界面。9.3.3学生管理信息系统的设计在设计阶段,首先要设计类的状态的图。类的状态图说明了可能的状态以与需要被处理的过渡期,使用状态图可以揭示单个对象在整个系统中的变化细凶,对了解和实现关键类有较大的帮助。不是所有的类都有状态图,在本系统中,有状态图的类是学生。学生的状态图如图5所示。图5学生的状态图设计阶段的最后一步是设计UML模型,也就是将前面设计的模型进竽扩展和细化。下面给出各个用例的时序图。设计的目的是产生一个可以使用的解决方案,并且可以容易地将方案转换成程序代码。学生的时序如图6所示图6学生时序图成绩的时序如图7所示。图7成绩时序图学籍变更的时序如图8所示。图8学籍变更时序图奖励的时序如图9所示。图9奖励时序图处罚的时序如图10所示。图10处罚时序图查询修改的时序如图11所示。图11查询修改时序图时序图设计完成后,开始进行学生管理信息系统的架构设计和细节设计。在架构设计中将定义包(子系统)、包间的相关性和基本的通信机制。设计架构时,应该将应用逻辑和技术逻辑分割。应用逻辑是需要编码设计的,而技术逻辑,主要包括用户界面、数据库或者通信一般是已经有的。学生管理信息系统中的包(或者为子系统、层)有如下几个,如图9-12所示。图9-12包和包间关系用户界面包(User Interface Package):为通用用户界面类,调用业务对象包中的操作检索和插入数据,可以简单地把它们看成将来用户要操作的界面。业务对象包(Business Object Package):业务对象包包含上面设计的分析模型的域类。业务对象包同数据库包协同完成任务。数据库包(Database Package):数据库包向业务对象数据包提供服务。应用包(Utility Package):应用包向其他包提供服务。至此,UML系统建模完成。9.4系统配置优秀的数据库系统必有一个相对最优的系统配置方案。系统配置要根据用户的实际情况设计,主要依据就是系统的吞吐量和系统对稳定性的要求,此外,用户的维护水平也是一个重要的方面。9.4.1软件配置软件配置主要包括数据库的选择和操作系统的选择。学生管理信息系统的软件配置要根据用户对系统的稳定性要求、系统的容量以与用户的维护水平来确定。(1)数据库选择可以根据数据量的大小选择不同的数据库,如表1所示。数据量是指数据库中需存放的单表的最大记录数。表1学生管理信息系统数据库的选择用 户数据量(记录表)稳定性要求维护水平备选数据库社区小学100500低差Access、Foxpro公立小学或社区小学5005000低差Access、Foxpro公立中学或社区大学500050000中一般SQL Server专业型大学50000200000较高较好SQL Server、Oracle综合型大学200000高好Oracle在本系统中,选择Access2000数据库。(2)操作系统选择可以根据用户量的大小选择不同的操作系统。操作系统的选择如表2所示。表2学生理管信息系统操作系统的选择用 户每秒数据库并发数据访问记录数稳定性要求维护水平备选操作系统社区小学1050低差Windows 2000 ProfessionalWindows 2000 Professional公立小学或社区中学50500中一般Windows NTWindows 2000 Server公立中学或社区大学5002000较高较好Windows NTWindows2000 ServerLinux、UNIX专业型大学5002000较高较好Linux、UNIX综合型大学2000以上高好Linux、UNIX在本例中,选择Windows 2000 Server操作系统。9.4.2硬件配置硬件配置主要包括客户端硬件的选择和服务器端硬件的选择。学生管理信息系统的硬件配置要根据用户对系统的稳定性要求、系统的容量、系统的吞吐量以与用户的维护水平来确定。(1)客户端硬件选择可以根据稳定性要求选择不同的客户端。一般情况下,对客户端的要求不高。如表3所示。表3学生管理信息系统客户端硬件的选择用 户稳定性要求备选客户端查询客户端低Pentium CPU/64MB/4GB管理客户端中Pentium /256MB/20GB(2)服务器端硬件选择可以根据数据量和吞吐量的大小选择不同的服务器硬件。服务器端的选择如表9-4所示。表4 学生管理信息系统服务器端硬件的选择用 户每秒数据库并发数据访问记录表稳定性要求维护水平备选服务器社区小学950低差Pentium /256MB/20GB个人计算机公立小学或社区中学50500中一般双CPU/1GB/RAID5372GB公立中学或社区大学50500中一般双CPU/1GB/RAID5372GB专业型大学5002000较高较好强4CPU/4GB/RAID5672GB综合型大学2000以上高好小型计逄机/双机热备当然,这种配置不是绝对的,这里只给出参考配置的围。具体的配置需要根据用户的需求和建设经费精确计算。9.4.3网络配置学生管理信息系统的网络配置一般有如下几种类型。(1)单机模式:即服务器和客户端在一台计算机上。(2)百兆模式:计算机网络的速度为百兆,如图13所示。(3)千兆模式:计算机网络的速度为千兆,实际上,没有必要给每个节点都配备千兆网络接口,只需要服务端配备千兆接口即可,如图14所示。图13学生管理信息系统网络百兆配置图14学生管理信息系统网络千兆配置在实际的运行中,可以根据用户情况选择不同的网络配置,如表5所示。表5学生管理信息系统配置的选择用 户每秒数据并发数据访问记录数稳定性要求维护水平备选网络方案社区小学1050低差单机模式公立小学或社区中学50500中一般百兆模式公立中学或社区大学50500中一般百兆模式专业型大学5002000较高较好百兆模式综合型大学2000以上高好千兆模式9.5数据库分析在开发学生管理信息系统时,可以先进行E-R图分析,然后对表和字段进行分析,最后进行数据库建模。9.5.1E-R图分析对学生管理信息系统的E-R图分析是建立在UML系统模型基础上的。这里给出E-R图分析的结果。实体关系图的分析结果非常复杂,一般情况下使用从简到繁的方式进行设计。首先从大的方面设计出各个实体之间的关系,然后在这个关系的基础上进行细化。图15所示为学生管理信息系统的实体关系简图。图15学生管理信息系统的实体关系简图在简图的基础上进一步设计实体关系的详细结构。图16所示为学生管理信息系统的实体关系详图。图916只是学生管理信息系统最基本元素的实体关系图,可以在此基础上根据用户的不同需要进行扩展。图16学生管理信息系统的实体关系图9.5.2表/字段分析和数据库建模表/字段分析是建立在实体关系图基础上。对表和字段分析后就可以建立数据库模型了。以图16所示的学生管理信息系统的实体关系图为基础,可设计表和字段,然后建立数据库模型。建立的数据库模型如图17所示。图9学生管理信息系统的数据库模型9.6数据库设计数据库设计与应用等程序设计是分离的,数据库的设计非常重要。有了数据库模型,数据库的设计就简单多了。在学生管理信息系统中,首先要创建学生管理信息系统数据库,然后在数据库中创建需要的表和字段。下面分别讲述本系统中数据库的设计。本例采用Access2000数据库系统来进行数据库的设计。9.6.1创建数据库下面给出在Access中创建数据库的过程。(1)运行Access应用程序,在“新建数据库”选项组中选取“空Access数据库”单选,按钮,然后单击“确定”按钮,如图18所示。(2)在“文件新建数据库”窗口指定数据库的存放位置与数据库文件名称(本例为Stu.mdb)然后单击“创建”按钮,如图19所示。图18新建数据库 图19指定数据库的存放位置与数据库文件名称9.6.2创建表下面给出在Access 中创建表的过程。(1)在创建数据库后,进入主界面,单击“Stu:数据库”子窗口中的“设计”按钮。此时将会出出“表1:表”窗口,如图20所示。图20开始设计表(2)在表的设计窗口“表1:表”中,按表6建立数据字段,并指定字段的数据类型与相关属性。表6学生信息数据库(Stuinfo)字 段 名 称数 据 类 型说 明StuId数字编号StuNo数字学号DepartMent文本院系Class文本班级Name文本Sex文本 性别 BirthDay 日期/时间 生日 NativePlace 文本 籍贯建立数据库字段并指定字段的数据类型与相关属性后,字段设计界面如图21所示。(3)在StuId字段上单击鼠标右键,选择快捷菜单中的“主键”选项,让StuId字段成为主要索引字段,则StuId 字段前方将出邮一个钥匙图标,如图22所示。图21字段设计 图22设置“StuId”字段为主键(4)字段设计完毕后,单击工具栏中的“保存”按钮,此时将会出现“另存为”对话框,在“表名称”文本框输入“StuInfo”,如图23所示,然后单击“确定”按钮将这个表保存。(5)回到“Stu:数据库”子窗口中,如果出现了StuInfo 这个表项目,就代表现在已经完成学生数据文件的设计,如图24所示。图23保存表 图24完成数据库中的表创建工作(6)重复步骤(1)(5),按表7、表8、表9、表10建立表,并指定表中各字估的数据类型与相关属性。表7字籍变更数据表(Change)字 段 名 称数 据 类 型说 明StuNo 数字学号Name 文本Class文本 班级DeparMent文本 院系ChangeName文本 学籍变更项ChangeTime 日期/时间 学籍变更时间Remark 文本 备注图8学生奖励数据表(Encourage)字 段 名 称数 据 类 型说 明 StuNo 数字 学号 Name 文本 Class 文本 班级 DeparMent 文本 院系 EncourageName 文本 奖励项 EncourageTime 日期/时间 奖励时间表9学生处罚数据表(Punish)字 段 名 称数 据 类 型说 明 StuNo 数字 学号 Name 文本 Class 文本 班级 DepartMent 文本 院系 PunishName 文本 处罚项 PunishTime 日期/时间 处罚时间表10学生成绩数据表(Score)字 段 名 称数 据 类 型说 明 ScoreId 数字 编号 StuNo 数字 学号 Name 文本 Course 文本 课程 Score 数字 成绩(7)将这些表分别名为Change、Encourage、Punish、Score,主键分别为:StuNo、StuNo、StuNo、Scoreld,设计结果如图25所示。,(8)回到“Stu:数据库”子窗口中,出现了StuInfo、Change、Encourage、Punish、Scores个表项目,完成数据文件的设计,如图26所示。图25完成数据库表项目的设计 图26完成后端数据库创建工作9.7界面设计以上容完成了数据库的后台工作,建立起了能够保障系统顺利、正确运行的后台。界面设计工作在进行系统开发的时候是必不可少,也是十分重要的。下面就对学生管理信息系统的界面设计。9.7.1用户登录界面设计利用用户登录成功能实现对用户操作权限的限制。管理员和学生的权限不一样,管理员拥有系统的所有权限,学生只有查询修改个人信息和打印成绩单的权限。用户必须输入正确的密码才能进入下一界面,如果用户的密码输入错误,应用程序会提示错误信息。用户如果连续3次输入错误,应用程序会强迫使用者退出并终止应用程序的运行,图27所示是用户登录界面窗体。9.7.2学生管理信息系统主界面设计学生管理信息系统主界面主要实现新生信息录入、成绩管理、学籍变更、处罚管理、奖励管理和查询修改的功能。选择该界面中工具栏中的不同按钮,就会进入实现不同功能的窗体。图28是图书馆理系统主界面窗体。图27用户登录界面窗体 图28学生管理信息系统主界面窗体这里主要介绍与数据库相关的组件的属性,如表11所示。表11学生管理信息系统主界面中数据库组件的属性设置组 件属 性属 性 值 Table1 DatebaseName Student TableName Stulnfo Table2 DatebaseName Student TableName Change Table3 DatebaseName Student TableName Encourage Table4 DatebaseName Student TableNsam Punish Table5 DatebasdeName Student TableName Score Query1 DatebaseName Student Query2 DatebaseName Student Query3 DatebaseName Student Query4 DatebaseName Student Query5 DatebaseName Student DataSource1 DataSet Table1 DataSource2 DataSet Query2 DataSource3 DataSet Query3 DataSource4 DataSet Query4 DataSource5 DataSet Table5 DataSource6 DataSet Query59.7.3 新生信息录入界面设计新生信息录入界面主要实现学生信息的添加功能,包括学号、性别、出生日期、籍贯、班级、所属院系等信息的添加,图29是新生信息录入界面窗体。图29新生信息录入界面窗体9.7.4 成绩管理界面设计成绩管理界面主要实现成绩的添加和校对修改的功能,图30是成绩管理界面窗体。图30成绩管理界面窗体9.7.5 学籍变更界面设计学籍变更界面是实现学生学籍变更的功能,图31是学籍变更界面窗体。图31学籍变更界面窗体9.7.6 奖励管理界面设计当学生在校表现优秀,学校应该奖励该学生,以鼓励大家的学习热情。奖励管理界面用于实现学生奖励的功能。相应的奖项有校特等奖、校一等校、校二等校、校三等校、工作奖等,用户可以根据实际情况进行设计。图32是奖励管理界面窗体。图32奖励管理界面窗体9.7.7处罚管理界面设计当学生在校的表现差,学校应该处罚该学生。处罚管理界面就是实现学生处罚的功能。相应的处罚项有警告、记过、开除等,用户可以根据实际情况进行设计。图33是处罚管理界面窗体。图33处罚管理界面窗体9.7.8查询修改界面设计学生可以根据自己的学号在查询修改界面中查询自己的个人信息,包括基本信息、个人成绩、学籍变更情况、奖励和处罚情况。如果发现基本信息有错误的话,有权进行修改,而且学生有权打印自己的成绩单。图9-34是查询修改界面窗体。图34查询修改界面9.8代码分析与实现上面对程序界面设计进行了详细的设计,基本完成了程序界面的设计工作。程序代码是程序的核心所在,是系统开发的灵魂。下面对系统的代码做具体的分析。9.8.1用户登录的代码实现学生管理信息系统启动时,首先出现的是系统主界面。单击系统主界面中工具栏的“用户登录”按钮,就弹出用户登录界面。程序从配置文件中获取管理员和学生的密码,和用户输入的密码比较,如果密码正确,则根据身份配权限;如果不正确,则提示用户重输或退出:重输3次以上,系统自动退出。代码如下:Proctdure TLoginFrm.BitBtn1Click(Sender:TObject);/“用户登陆”按钮的单击事件Var pwdfile:textfile;PwdStr:string;Beginif RadioButton1.checked=True then assingnfile(pwdfile,.Admini.cfg); if RadioButton2.checked=True then assingfile(pwdfile,.student.cfg); reset(pwdfile); readln(pwdfile,pwdStr); closefile(pwdfile); Times:=Times=1;If edit1.Text=PwdStr then begin close; StuMainFrm.Enabled:=True StuMainFrm.PageControll.ActivePage:=StuMainFrm.Tabsheet6; StuMainFrm.PageControll.Visible:=true;if Radiobuttonl.checked=True then begin StuMainFrm.ToolButton2.Enabled:=Ture; StuMainFrm.Toolbutton3.Enabled:=True; StuMainFrm.ToolButton4.Enabled:=True; StuMainFrm.ToolButton5.Enabled:=True; StuMainFrm.ToolButton8.Enabled:=True; StuMainFrm.ToolButton6.Enabled:=True; end; if RadioButton2.checked=True then begin StuMainFrm.ToolButton6.Enabled:=True; end;endelsebegin if MessageDlg(密码输入错误,是否退出?,mtContirmation,mbYes,mbNo,0)=mryes then begin close; StuMainFrm.Enabled:=True; end else begin if times3 then editl.SetFocus else begin MessageDlg(对不起,密码输入严重错误,请退出!,mtInformation,mbOk,0); Application.Terminate; end;end;end;end;为了防止用户多次重输密码,限制了输入了次数为3次,因此需要对次数进行初始化,活加代码如下:Procedure TLoginFrm.FormShow(Sender:TObject);Begin Times:=0;End;9.8.2 成绩管理的代码实现当管理员选择了一位学生后,输入各科成绩,程序把数据保存到数据库。代码如下:Procedure TStuMainFrm.BitBtn9Click(Sender:TObject);/“添加”按钮的单击事件var StuNo,StuName:string; i:integer;begin with Query do begin close; Sql.Clear; Sql.Add(Select StuNo from Score Whers StuNo=+DbEdit6.Text+); Open; if recordcount=0 then begin StuNo:=DbEdit6.Text; StuName:=DbEdit7.Text; for i:=l to 12 do begin if Coursei0then with Table5 do begin Open; Append; SetFields(nil,StuNo,kStuName,Coursei,Scorei); Post; end;end;end else MessageDlg(对不起,该记录已经存在!,mtInformation,mbOk,0);end;end;9.8.3 学籍变更的代码实现当管理员选择了学籍需要变更的学生后,输入变更项和变更时间,程序把数据保存到数据库。代码如下:procedure TStuMainFrm.BitbtnlClick(Sender: Tobject);/“添加”按钮的单击事件var StuNo,StuName,StuClass,StuDepart.ChangeName,ChangeRemark:string;begin winth Table2 do begin Open; StuNo:=Editl.text; StuName:=Edit2.text; StuClass:=Edit3.text; StuDepart:=Edit4.text; ChangeName:=ComboBoxl.Text; ChangeRemark:=Edit5.text; append; SetFields(StuNo,StuName,StuClass,StuDepart,ChangeName,ChangeRemark,Formatdatetime(dddddde,DateTimePicker2.Dat); Post; end;end;9.8.4 奖励管理的代码实现当管理员选择了需要奖励的学生后,选择了奖项和奖励时后,程序把数据保存到数据库。代码如下:procedure TStuMainFrm.bitbtn3Click(Sender: TObject);/“添加”按钮的单击事件var StuNo,StuName,StuClass,StuDepart,EncourageName:sering;begin with Table3 do begin Open; StuNo:=Edit6.text; StuName:=Edit7.text; StuClass:=Edit8.text; StuDepart:=Edit9.text; if RadioButtonl.checked=true then EncourageName:=RadioButtonl.Caption; if RadioButton2.checked=true then EncourageName:=RadioButton2.Caption; if RadioButton3.checked=true then EncourageName:=RadioButton3.lCaption; if RadioButton4.checked=true then EncourageName:=RadioButton4.Caption; if RadioButton5.checked=true then EncourageName:=RadioButton5.Caption; if RadioButton6.checked=true then EncourageName:=RadioButton6.Caption; if RadioButton7.checked=true then EncourageName:=RadioButton7.Capiton; if RadioButton8.checked=true then EncourageName:=RadioButton8.Caption; append; SetFields(StuNo,StuName,StuClass,StuDepart,EncourageName,Formatdatetime(dddddd,DateTimePickerl.Dat); Post; end;end:外罚管理的代码和奖励管理的代码类似,这里不再 述。9.8.5查询/修改的代码实现当学生根据自己的学号查询了自己的信息,如果发现有错的话,可以修改,然后程序把修改后数据保存到数据库。代码如下:procedure TStuMainFrm.BitBtn7Click(Sender:TObject);/“修改”按钮的单击事件var StuNo,StuName,StuClass,StuDepart,StuSex,Birthdayt,NativePlace:string;beginwith Tablel do begin Open; StuNo:=Editl4.text; StuName:=Editl5.text; StuClass:=Editl6.text;StuDepart:=Editl7.text; NativePlace:=Editl9.text; Birthday:=Edit20.text; if RadioButtonl2.checked=true then StuSex:=RadioButtonl2.Caption; if RadioButtonl6,checked=true then StuSex:=RadioButtonl6.Caption; Edit; SetFields(StuNo,StuDepart,StuClass,StuName,StuSex,Birthday,NativePlace); Post; end;end;学生可以打印成绩单,其代码很简单,这里不再列出。9.9实例演示至此,学生管理信息系统的开发基本结束。下面演示这个系统,来看看实际的效果如何。运行学生管理信息系统的执行文件StuMain.exe,首先出现的是学生管理信息系统的主界面,它有一个工具栏,上面有8个按钮,依次是:用户登录、新生信息录入、成绩管理、学籍变更、奖励管理、处罚管理、查询修改和退出,其中只有“退出”和“用户登录”是激活的,其他是不可用的,需要登录后再分配权限,如图35所示。图35学生管理信息系统的主界面单击“退出”按钮,则退出系统。单击“用户登录”按钮,则弹出用户登录界面,如图36所示。用户选择自己的身份,输入相应的密码即可拥有相应的权限。首次登录密码都是“888888”。如果输入的密码不正确,则提示用户是否退出,如图37所示。如果输入的密码3次以上不正确,则自动退出系统,如图38所示。图36用户登录界面 图37提示用户 图38自动退出系统如果身份是管理员,而且输入的密码正确,则分配给管理员所有的权限,如图39所示。如果身份是学生,而且输入的密码正确,则分配给学生查询修改的权限,如图40所示。图39管理员拥有的权限图40学生拥有的权限现在假设以管理员的身份登录了系统,这样就拥有了所有的权限,下面就是逐个演示各个系统功能。9.9.1新生信息录入的实例演示单击“新生信息录入”按钮,弹出新生信息录入界面,如图41所示,单击导航条上按+按钮,输入相应的学生信息,选择班级和院系,单击导航条上的按钮,新生信息就保存到了数据库。图41新生信息录入实例演示9.9.2成绩管理的实例演示单击“成绩管理”按钮,则出现成绩管理界面,如图42所示。单击导航条上的和按钮查找学生,学号、自动从数据库中调出,录入学生的各科成绩,单击“添加”按钮,学生成绩就保存到了数据库。在右边的表中,浏览到相应的记录,如果需要修改,单击导航条上的按钮,输入相应的成绩,再单击导航条上的按钮,修改后的信息就保存到了数据库。图42成绩管理实例实示9.3.3 学籍变更的实例演示单击“学籍变更”按钮,出现学籍变更界面,如图43所示。输入学生的学号,等信息自动从数据库中调出,录入变更项和变更时间,单击“添加”,学籍变更信息就保存到了数据库。图43学籍变更实例演示9.9.4 奖励管理的实例演示单击“奖励管理”按钮,出现奖励管理界面,如图44所示。输入学生的学号,等信息自动从数据库中调出,选择奖励项和奖励时间,单击“添加”按钮,奖励信息就保存到了数据库。图44奖励管理实例演示9.9.5 外罚管理的实例演示单击“外罚管理”按钮,出现外罚管理界面,如图45所示。输入学生的学号,等信息自动从数据库中调出,选择处罚项和处罚时间,单击“添加”按钮,处罚信息就保存到了数据库。图45处罚管理实例演示9.9.6 查询修改的实例演示单击“查询修改”按钮,出现查询修改界面,如图46所示。输入学生的学号,等信息自动从数据库中调出。如果发现信息有错,可以在相应的编辑框输入正确的信息,单击“修改”按钮,成绩单效果如图47所示。图46查询修改实例演示图47打印成绩单实例演示参考文献1 海藩,软件工程导论,清华大学,20022伍俊良,Delphi 6控件应用实例教程,希望电子,20023卢国俊,Delphi 6数据库开发,电子工业,20024边萌,Delphi 编程起步,机械工业,20025伍俊良,Delphi 6课程设计案例精编,中国水利水电,20026丁宝康,数据库原理,经济科学,20007陆丽娜,软件工程,经济科学,20008 许杰舟、林伟鹏、林盛雄、来宾,Delphi7程序设计与实例,20039 志刚、何志成、志强、王忠华,Delphi5.0程序设计 基础教学篇,37 / 37
展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 办公文档 > 模板表格


copyright@ 2023-2025  zhuangpeitu.com 装配图网版权所有   联系电话:18123376007

备案号:ICP2024067431-1 川公网安备51140202000466号


本站为文档C2C交易模式,即用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知装配图网,我们立即给予删除!