1、- 1 -第一章 前言科技在进步,学生成绩管理系统已成为学校等教育部门不可缺少的部分,它的应用内容对于学校领导和用户来说非常重要,因为学生成绩管理系统能够为用户提供充足的信息和快捷的查询手段。由于一直以来人们使用传统的人工方式管理文件成绩,这种管理方式存在着许多缺点,如:效率低、保密性差,另外时间一长,将产生大量的文件和数据,这对于查找、更新和维护都带来了不少的困难。使用计算机来管理学生成绩,不但可以节省时间和人力资源,更能全面、高效地掌握学生基本情况等信息,并及时获取最新的准确资料和信息,使效率大大提高。该设计是一个管理学生成绩的系统,功能与实现方面有相当的针对性和实用性。本文详细地介绍了“
2、学生成绩管理系统”的设计思想,设计过程,本软件是在 VISUAL Foxpro 平台上开发的,采用 Access2000 做为数据库,严格按照关系数据库原理、思想的有关规定进行数据库的设计,数据操作语言采用 SQL 中的有关命令,能方便地实现对数据库的操作与管理。本文从问题定义、可行性研究、需求分析、概要设计、详细设计、编码,软件的测试等方面对该软件进行了详细的说明,它是软件的一个非常重要的文档资料,是毕业设计的文字说明材料本学生成绩管理系统是典型的信息管理系统(MIS),其开发主要包括后台数据库的建立和维护以及前端应用程序的开发两个方面。对于前者要求建立起数据一致性和完整性强、数据安全性好的
3、库。而对于后者则要求应用程序功能完备,易使用等特点。- 2 -第二章 系统分析2.1 需求分析在 21 世纪的信息科技时代,科学技术突飞猛进,计算机已经应用到广泛的领域,而且越来越贴近于我们的现实生活。如今,不管是小学,初中,高中,甚至是很多大学生的学生成绩管理基本上是靠人工进行管理,但随着时间的变化,学校规模的扩大,有关学生成绩管理工作和所涉及到的数据量也会越来越多,大多数学校不得不靠增加人力,物力,财力来进行学生成绩管理。但人工管理成绩档案具有效率低,查找麻烦,可靠性不高,保密性低等因素。因此开发出一个不仅仅是适用于大中专院校以及其它高校通用的学生成绩管理系统是必要的。根据多数学校的基本情
4、况,该系统主要是实现数据的更新,查询,统计,并且可以生成相应的报表文件。数据更新包括以下几个方面: (1)学生记录的增加,删除,修改,可以方便的实现记录的改动。 (2)课程资料的添加,删除,修改。(3)学生成绩输入,学期结束,要对成绩表中的学生成绩进行登记。 数据查询和统计包括以下几个方面: (1)学生成绩查询,包括快捷查询和组合查询,前者可以直接输入学号或姓名对全部的课程进行成绩查询,而后者可以查询某一课程所有学生的成绩情况,总之可以根据不同需要查询到不同的学生成绩名单,适用性更广。 (2)学生成绩统计,统计每个学生的总成绩。 (3)学生成绩排名,可以查看学生的名次号。 2.2 可行性分析随
5、着开发工具的发展,面向对象的、可视化的开发工具不断的涌现,如 VC+,VB,JSP,ASP,PHP 等,这些工具在第三代语言的基础上,能帮助软件开发者提高软件的开发的质量和效率,缩短开发周期。本系统采用 VB 开发环境以及 Windows XP 的操作系统为工作平台,同时借助 Microsoft Access2000 这一强大的数据库管理系统来实现所以开发此系统从技术上完全可行- 3 -第三章 系统设计3.1 设计目标实现学生资料和课程安排的添加、修改和删除; 学生成绩的添加、查询、修改和删除;使学校成绩管理人员更加便捷的对学生成绩进行管理。3.2 功能设计本系统提供用户为管理人员、三大模块(
6、资料、成绩、排名)。用户进入系统:一、查询、添加、修改和删除学生资料二、进入成绩修改模块,查询和修改学生成绩三、进入排名模块,查询学生成绩和排名情况 3.3 模块流程图本管理系统使用网络文件模块化设计方式来实现相应的管理功能,以下是本系统的主模块功能图。 图 3-1 系统模块示意图3.4 数据库设计主界面资料成绩排名课程资料学生资料查询、添加、修改、删除查询、修改学生成绩查询学生成绩查看学生名次- 4 -3.4.1 数据库结构本系统使用一个数据库 StuScore.mdb,其中包括的表结构如下:表 3-1 课程资料表(tbllession )序号 字段名 字段类型 字段大小1 课程 ID 自动
7、编号 长整型2 课程号 数字 长整型3 课程名称 文本 504 教材名称 文本 505 任课老师 文本 50表 3-2 学生成绩表(tblscore)序号 字段名 字段类型 字段大小1 学生成绩 ID 自动编号 长整型2 课程 ID 数字 长整型3 学生 ID 数字 长整型4 成绩 数字 长整型表 3-4 学生资料表(tblstudent )序号 字段名 字段类型 字段大小1 学生 ID 自动编号 长整型2 学生学号 文本 长整型3 学生名称 文本 504 性别 文本 505 入学日期 日期/时间- 5 -第四章 详细设计一、详细设计的任务详细设计的目的是为软件结构图(SC 图或 HC 图)中
8、的每一个模块确定使用的算法和块内数据结构,并用某种选定的表达工具给出清晰的描述。这一阶段的主要任务:1为每个模块确定采用的算法,选择某种适当的工具表达算法的过程,写出模块的详细过程性描述;2确定每一模块使用的数据结构;3确定模块接口的细节,包括对系统外部的接口和用户界面,对系统内部其它模块的接口,以及模块输入数据、输出数据及局部数据的全部细节。在详细设计结束时,应该把上述结果写入详细设计说明书,并且通过复审形成正式文档。交付给下一阶段(编码阶段)的工作依据。4要为每一个模块设计出一组测试用例,以便在编码阶段对模块代码(即程序)进行预定的测试,模块的测试用例是软件测试计划的重要组成部分,通常应包
9、括输入数据,期望输出等内容。二、详细设计的原则1由于详细设计的蓝图是给人看的,所以模块的逻辑描述要清晰易读、正确可靠。2采用结构化设计方法,改善控制结构,降低程序的复杂程度,从而提高程序的可读性、可测试性、可维护性。其基本内容归纳为如下几点。 (1) 程序语言中应尽量少用 GOTO 语句,以确保程序结构的独立性。(2) 使用单人口单出口的控制结构,确保程序的静态结构与动态执行情况相一致。保证程序易理解。(3) 程序的控制结构一般采用顺序、选择、循环三种结构来构成,确保结构简单。(4) 用自顶向下逐步求精方法完成程序设计。结构化程序设计的缺点是存储容量和运行时间增加 10-20,但易读易维护性好
10、。(5) 经典的控制结构为顺序,IF THEN ELSE 分支,DO-WHILE 循环。扩展的还有多分支 CASE,DO-UNTIL 循环结构,固定次数循环 DOWHILE。- 6 -3选择恰当描述工具来描述各模块算法。三、详细设计的方法详细设计的工具:图形工具利用图形工具可以把过程的细节用图形描述出来。表格工具可以用一张表来描述过程的细节,在这张表中列出了各种可能的操作和相应的条件。语言工具用某种高级语言(称之为伪码)来描述过程的细节。四、程序流程图程序流程图又称之为程序框图,它是软件开发者最熟悉的一种算法表达工具。它独立于任何一种程序设计语言,比较直观和清晰地描述过程的控制流程,易于学习掌
11、握。因此,至今仍是软件开发者最普遍采用的一种工具。流程图也存在一些严重的不足。流程图中只能使用下述的五种基本控制结构。1、顺序型顺序型由几个连续的处理步骤依次排列构成。顺序型 选择型 while 型循环2、选择型 选择型是指由某个逻辑判断式的取值决定选择两个处理中的一个。ABPABPS- 7 -3、while 型循环while 型循环是先判定型循环,在循环控制条件成立时,重复执行特定的处理。4、until 型循环until 型循环是后判定型循环,重复执行某些特定的处理,直到控制条件成立为止。5、多情况型选择多情况型选择列举多种处理情况,根据控制变量的取值,选择执行其一。until 型循环 多情
12、况型选择 五、N-S 图盒图是一种符合结构化程序设计原则的图形描述工具,又称之为 N-S 图。在N-S 图中,为了表示五种基本控制结构,规定了五种图形构件。1、顺序型在顺序型中,先执行 A,后执行 B。SPA AAAAAAAAABP=1P=2P=nA1A2An- 8 -顺序型结构2、选择型在选择型结构中,如果条件 P 成立,则可执行 T 下面的 A 的内容,当条件 P不成立时,则执行 F 下的内容。P T FS1S2 选择型结构3、WHILE 重复型在 WHILE 重复型循环结构中,先判断 P 的值,再执行 S。其中 P 是循环条件,S 是循环体。WHILE P S WHILE 重复型循环结构
13、 4、UNTIL 重复型在 UNTIL 重复型循环结构中,先执行 S,后判断 P 的值。SUNTIL PUNTIL 重复型循环结构5、多分支选择型- 9 -六、PAD 图PAD 是用结构化程序设计思想表现程序逻辑结构的图形工具。PAD 也设置了五种基本控制结构的图示,并允许递归使用。1、顺序型按顺序先执行 A,再执行 B。顺序型结构2、选择型下图给出了判断条件为 P 的选择型结构。当 P 为真值时执行上面的 A 框,P取假值时执行下面的 B 框中的内容。如果这种选择型结构只有 A 框,没有 B 框,表示该选择结构中只有 THEN 后面有可执行语句 A,没有 ELSE 部分。P选择型结构3、WH
14、ILE 重复型和 UNTIL 重复型P 是循环判断条件,S 是循环体。循环判断条件框的右端为双纵线,表示该矩形域是循环条件,以区别于一般的矩形功能域。WHILE P/UNT IL PWHILE 重复型和 UNTIL 重复型结构4、多分支选择型SABAB- 10 -多分支选择型是 CASE 型结构。当判定条件 P 等于 1 时执行 A1 框的内容,P等于 2 时执行 A2 框的内容,P 等于 N 时执行 An 框的内容。七、PDL (过程设计语言)PDL 是所有非正文形式的过程设计工具的统称,到目前为止已出现多种 PDL语言。PDL 具有“非纯粹”的编程语言的特点。1、PDL 语言的特点关键字采
15、用固定语法并支持结构化构件、数据说明机制和模块化;处理部分采用自然语言描述;可以说明简单和复杂的数据结构;子程序的定义与调用规则不受具体接口方式的影响。2、PDL 描述选择结构3、PDL 描述循环结构4、子程序5、输入/输出- 11 -第五章 程序总体结构1、学生成绩管理系统目录main2、流程图passMenus 基本数据管理系统维护学生成绩管理其他系统初始化退出系统 进入系统- 12 -3、功能框图注:图框中带*号者表示表单基本数据管量Main程序Pass*Menu学生成绩管理系统维护其他Sefprof*sreen*Setclass*usermcdn*przntsare*quscore*S
16、etcore*Setcomse*databado*qustadent*Setstudent*fenksql*Hflp*sefprofl*setcourfel*sefdassl*setseudentl*Setsfudenfz*setcorel*Fscore1报表Fscore报表文档UsemaninlFind*- 13 -第六章 实现过程1、数据表设计本系统使用的表均为自由表(1)user 表Field Fieldname Type Width Dec Index Nulls1 usename C 10 NO2 usepass C 6 NO 3 uselevelL C 10 N0该表存储系统用户信
17、息。(2)daywrife 表Field Fieldname Type width Dec Index Nulls1 usename QC 102 useDATE D 83 usefime D 8(3)prof 表(结构如下)Field Fieldname Type width Dec Index Nulls1 专业 C 20(4)classn 表(结构如下)Field Fieldname Type width Dec Index Nulls1 课程 C 6 N02 专业 C 20 NO3 课程 C 20 NO4 性质 C 6 NO5 开课学期 C 1 NO6 学分 N 3 NO- 14 -该
18、表用于每放所有课程信息, (课程按专业分类)(5)student 表(结构如下)Field Fieldname Type width Dec Index Nulls1 学号 C 8 N02 姓名 C 10 NO3 性别 C 2 NO4 出生日期 D 8 NO5 民族 C 10 NO6 专业 C 20 NO7 班号 C 10 NO8 备注 M 4 NO9 照片 G 4 NO该表按专业分类每班的所有学生记录,另有一个临时表 studentl,结构相同与 student。(6)score 表score 表结构如下:Field Fieldname Type width Dec Index Nulls1
19、 学号 C 5 N02 姓名 C 7 NO3 课程 C 20 NO4 分数 N 3 NO5 班号 C 5 NO6 专业 C 20 NO该表按班号分类存放学生成绩,另有一个临时表 scorel,其结构似同。2、系统程序代码学生成绩管理系统的程序、表单、代码如下:(所列出大部分)主程序 main.prgCLEARSET TALK OFF- 15 -SET SYSMENU offSET SYSMENU toSET DELETED OFFSET STATUS BAR OFFSET DATE ANSISET SAFETY OFFCLEAR ALLCLOSE ALL_Screen.WindowState=
20、2_Screen.Caption=“学生成绩管理系统“PUBLIC ulevel,rq AND scpass=ALLTRM isform.text2.valveIF FounD( )ftay=.T.uleval=uselevelTHISFORM:RELEASEELSE=MESSAGEBOX(“口令不正确,请重新输入” ,48, “信息提示”)THISFORM。TEXT1。VALUE=“”n=n+1THISFORM.TEXT1.SETFOCUSENDIFENDIFENDPROCPROCE RE commard2.clickFhisform.ReleaseRECEASE n,flagENDPROL
21、Menu.mpr 程序代码如下:SET SYSMENU TOSET SYSMENU AUTOMATICDEFINE PAD _0vv0ilzcv OF _MSYSMENU PROMPT “基本数据管理“ COLOR SCHEME 3DEFINE PAD _0vv0ilzd8 OF _MSYSMENU PROMPT “学生成绩管理“ COLOR SCHEME 3- 17 -DEFINE PAD _0vv0ilzd9 OF _MSYSMENU PROMPT “系统维护“ COLOR SCHEME 3DEFINE PAD _0vv0ilzda OF _MSYSMENU PROMPT “退出“ COL
22、OR SCHEME 3ON PAD _0vv0ilzcv OF _MSYSMENU ACTIVATE POPUP 基本数据管理ON PAD _0vv0ilzd8 OF _MSYSMENU ACTIVATE POPUP 学生成绩管理ON PAD _0vv0ilzd9 OF _MSYSMENU ACTIVATE POPUP 系统维护ON SELECTION PAD _0vv0ilzda OF _MSYSMENU ;DO _0vv0ilzdb ;IN LOCFILE(“VFP 学生成绩管理系统MENU“ ,“MPX;MPR|FXP;PRG“ ,“WHERE is MENU?“)DEFINE POPU
23、P 基本数据管 MARGIN RELATIVE SHADOW COLOR SCHEME 4DEFINE BAR 1 OF 基本数据管理 PROMPT “设置专业“DEFINE BAR 2 OF 基本数据管理 PROMPT “设置班号“DEFINE BAR 3 OF 基本数据管理 PROMPT “设置课程“DEFINE BAR 4 OF 基本数据管理 PROMPT “-“DEFINE BAR 5 OF 基本数据管理 PROMPT “录入学生“DEFINE BAR 6 OF 基本数据管理 PROMPT “查询学生“ON SELECTION BAR 1 OF 基本数据管理 ;DO _0vv0ilze
24、1 ;IN LOCFILE(“VFP 学生成绩管理系统MENU“ ,“MPX;MPR|FXP;PRG“ ,“WHERE is MENU?“)ON SELECTION BAR 2 OF 基本数据管理 ;DO _0vv0ilze2 ;IN LOCFILE(“VFP 学生成绩管理系统MENU“ ,“MPX;MPR|FXP;PRG“ ,“WHERE is MENU?“)ON SELECTION BAR 3 OF 基本数据管理 ;DO _0vv0ilze3 ;IN LOCFILE(“VFP 学生成绩管理系统MENU“ ,“MPX;MPR|FXP;PRG“ ,“WHERE is MENU?“)ON SEL
25、ECTION BAR 5 OF 基本数据管理 ;DO _0vv0ilze4 ;IN LOCFILE(“VFP 学生成绩管理系统MENU“ ,“MPX;MPR|FXP;PRG“ - 18 -,“WHERE is MENU?“)ON SELECTION BAR 6 OF 基本数据管理 do form qustudentDEFINE POPUP 学生成绩管理 MARGIN RELATIVE SHADOW COLOR SCHEME 4DEFINE BAR 1 OF 学生成绩管理 PROMPT “学生成绩录入“DEFINE BAR 2 OF 学生成绩管理 PROMPT “-“DEFINE BAR 3 O
26、F 学生成绩管理 PROMPT “学生成绩查询“DEFINE BAR 4 OF 学生成绩管理 PROMPT “-“DEFINE BAR 5 OF 学生成绩管理 PROMPT “学生总成绩“ON SELECTION BAR 1 OF 学生成绩管理 ;DO _0vv0ilze5 ;IN LOCFILE(“VFP 学生成绩管理系统MENU“ ,“MPX;MPR|FXP;PRG“ ,“WHERE is MENU?“)ON SELECTION BAR 3 OF 学生成绩管理 do form quscoreON SELECTION BAR 5 OF 学生成绩管理 do form printscoreDEF
27、INE POPUP 系统维护 MARGIN RELATIVE SHADOW COLOR SCHEME 4DEFINE BAR 1 OF 系统维护 PROMPT “用户管理“DEFINE BAR 2 OF 系统维护 PROMPT “-“DEFINE BAR 3 OF 系统维护 PROMPT “数据备份“DEFINE BAR 4 OF 系统维护 PROMPT “-“DEFINE BAR 5 OF 系统维护 PROMPT “系统初始化“ON SELECTION BAR 1 OF 系统维护 ;DO _0vv0ilze6 ;IN LOCFILE(“VFP 学生成绩管理系统MENU“ ,“MPX;MPR|
28、FXP;PRG“ ,“WHERE is MENU?“)ON SELECTION BAR 3 OF 系统维护 ;DO _0vv0ilze7 ;IN LOCFILE(“VFP 学生成绩管理系统MENU“ ,“MPX;MPR|FXP;PRG“ ,“WHERE is MENU?“)ON SELECTION BAR 5 OF 系统维护 ;DO _0vv0ilze8 ;IN LOCFILE(“VFP 学生成绩管理系统MENU“ ,“MPX;MPR|FXP;PRG“ - 19 -,“WHERE is MENU?“)* * * * * _0VV0ILZDB ON SELECTION PAD * * * * P
29、rocedure Origin: * * * * From Menu: MENU.MPR, Record: 30 * * Called By: ON SELECTION PAD * * Prompt: 退出 * * Snippet: 1 * * * *PROCEDURE _0vv0ilzdbset sysmenu to defaultCLEAR EVENTS* * * * * _0VV0ILZE1 ON SELECTION BAR 1 OF POPUP 基本数据管理 * * * * Procedure Origin: * * * * From Menu: MENU.MPR, Record: 5
30、 * * Called By: ON SELECTION BAR 1 OF POPUP 基本数据管理 * * Prompt: 设置专业 * * Snippet: 2 * * * *PROCEDURE _0vv0ilze1IF ulevel=“系统管理员“- 20 -do form setprofELSE=MESSAGEBOX(“您不是系统管理员,不能使用本项功能“,16+0,“信息提示“)ENDIF* * * * * _0VV0ILZE2 ON SELECTION BAR 2 OF POPUP 基本数据管理 * * * * Procedure Origin: * * * * From Menu
31、: MENU.MPR, Record: 6 * * Called By: ON SELECTION BAR 2 OF POPUP 基本数据管理 * * Prompt: 设置班号 * * Snippet: 3 * * * *PROCEDURE _0vv0ilze2IF ulevel=“系统管理员“do form setclassELSE=MESSAGEBOX(“您不是系统管理员,不能使用本项功能“,16+0,“信息提示“)ENDIF* * * * * _0VV0ILZE3 ON SELECTION BAR 3 OF POPUP 基本数据管理 * * * * Procedure Origin: *
32、 * * * From Menu: MENU.MPR, Record: 7 * * Called By: ON SELECTION BAR 3 OF POPUP 基本数据管理 - 21 -* * Prompt: 设置课程 * * Snippet: 4 * * * *PROCEDURE _0vv0ilze3IF ulevel=“系统管理员“do form setcourseELSE=MESSAGEBOX(“您不是系统管理员,不能使用本项功能“,16+0,“信息提示“)ENDIF* * * * * _0VV0ILZE4 ON SELECTION BAR 5 OF POPUP 基本数据管理 * *
33、* * Procedure Origin: * * * * From Menu: MENU.MPR, Record: 10 * * Called By: ON SELECTION BAR 5 OF POPUP 基本数据管理 * * Prompt: 录入学生 * * Snippet: 5 * * * *PROCEDURE _0vv0ilze4IF ulevel=“系统管理员“do form setstudentELSE=MESSAGEBOX(“您不是系统管理员,不能使用本项功能“,16+0,“信息提示“)ENDIF* *- 22 -* * * * _0VV0ILZE5 ON SELECTION
34、BAR 1 OF POPUP 学生成绩管理 * * * * Procedure Origin: * * * * From Menu: MENU.MPR, Record: 14 * * Called By: ON SELECTION BAR 1 OF POPUP 学生成绩管理 * * Prompt: 学生成绩录入 * * Snippet: 6 * * * *PROCEDURE _0vv0ilze5IF ulevel=“系统管理员“do form setscoreELSE=MESSAGEBOX(“您不是系统管理员,不能使用本项功能“,16+0,“信息提示“)ENDIF* * * * * _0VV0
35、ILZE6 ON SELECTION BAR 1 OF POPUP 系统维护 * * * * Procedure Origin: * * * * From Menu: MENU.MPR, Record: 23 * * Called By: ON SELECTION BAR 1 OF POPUP 系统维护 * * Prompt: 用户管理 * * Snippet: 7 * * * *PROCEDURE _0vv0ilze6IF ulevel=“系统管理员“- 23 -do form usermainELSE=MESSAGEBOX(“您不是系统管理员,不能使用本项功能“,16+0,“信息提示“)E
36、NDIF* * * * * _0VV0ILZE7 ON SELECTION BAR 3 OF POPUP 系统维护 * * * * Procedure Origin: * * * * From Menu: MENU.MPR, Record: 26 * * Called By: ON SELECTION BAR 3 OF POPUP 系统维护 * * Prompt: 数据备份 * * Snippet: 8 * * * *PROCEDURE _0vv0ilze7IF ulevel=“系统管理员“do form databackELSE=MESSAGEBOX(“您不是系统管理员,不能使用本项功能“,
37、16+0,“信息提示“)ENDIF* * * * * _0VV0ILZE8 ON SELECTION BAR 5 OF POPUP 系统维护 * * * * Procedure Origin: - 24 -* * * * From Menu: MENU.MPR, Record: 29 * * Called By: ON SELECTION BAR 5 OF POPUP 系统维护 * * Prompt: 系统初始化 * * Snippet: 9 * * * *PROCEDURE _0vv0ilze8IF MESSAGEBOX(“真的要进行系统初始化吗?“,4+32,“确认“)=6IF uleve
38、l=“系统管理员“USE user IN 0SELECT userZAPAPPEND BLANKREPLACE usename WITH “system“,usepass WITH “manager“,uselevel WITH “系统管理员“USE IN userUSE student IN 0SELECT studentZAPCOPY TO student1USE IN studentUSE student1 IN 0SELECT student1APPEND BLANKUSE IN student1USE score IN 0SELECT scoreZAPUSE IN scoreUSE prof IN 0SELECT prof- 25 -ZAPUSE IN profUSE classn IN 0SELECT classnZAPINDEX ON 专业+班号 +STR(入校