1、目录考务管理系统 2摘 要 2关键词: 2Test management system2Summary21 前言 .31.1 背景 31.2 开发意义 32 系统设计要求 .42.1 系统需求分析 42.1.1 任务概述 .42.2 考务管理系统设计要求 42.2.1 系统设计目标 .42.2.2 系统设计原则 .42.3 系统可行性分析 52.3.1 经济可行性分析 .52.3.2 操作可行性分析 .52.3.3 技术可行性分析 .52.4 系统参与者描述 .62.5 系统用例图 62.6 系统功能要求描述 72.6.1 学生模块 .72.6.2 教师模块 .72.6.3 管理员模块 .83
2、 系统开发环境和工具 .84 系统详细设计 94.1 系统功能模块设计 94.2 数据库表设计 94.3 系统主要模块设计 124.3.1 考场安排模块 .124.3.2 考场安排查询模块 .135 系统的实现 .145.1 系统部署图 145.2 系统人机交互设计 145.3 SQL Server 2005 服务器中使用存储过程 156 系统功能测试 157 总结 .15参考文献 16考务管理系统摘 要本文针对高校繁杂的考务信息管理这个问题,利用程序设计的思想,给出了减轻人工安排考场、监考的方案。使用 ASP.NET 技术开发系统,利用随机安排,检测冲突的思想,结合 SQL SERVER 2
3、005 数据库,采用 B/S 模式,从不同用户的角度出发,实现了课程管理,考场安排,考生信息管理,监考管理,考场管理,查询成绩,查询考试信息等功能,改变了传统的管理模式,运用现代化手段进行科学管理。此外系统还支持发布各类考试公告,将考试安排导出excel 等功能。系统界面柔和,惬意,给以用户亲切,舒适感。关键词:考务信息管理、ASP.NET、SQL SERVER 2005、B/S 模式Test management systemSummaryThis paper focuses on complicated the question of the examination information
4、 management in colleges and universities, using programming ideas, reduce artificial arrangements are given examination, proctored programmes. Using ASP. NET technology development system, using random arrangements, excluding conflict of thought, combined with SQL SERVER 2005 database from a differe
5、nt perspective of the user, enabling course management, examination arrangements, information management candidates, proctored management, test management, query results, and query features such as exam information , changing the traditional management mode, use of modern means of scientific managem
6、ent. In addition system also supports the release of various test bulletin, export the examination arrangement features such as Excel. System interface a soft, comfortable, user friendly and comfort. Key words: examination information, ASP. NET, SQL SERVER 2005, B/S Model1 前言随着高校招生规模的不断扩大,新专业不断开设,课程
7、不断增加,考务管理工作量不断加大,尤其是考场编排这项非常重要而繁琐的工作,若是再依靠传统的手工编排方式进行,那将浪费大量的人力、时间和资源。 针对这种情况,借助计算机技术辅助解决教学资源浪费的问题,寻找合理、高效、科学的考务管理方式显得非常之急需而重要。1.1 背景信息时代飞速发展的今天,很多的行业、事业单位都已经步入计算机的世界, 依靠计算机开发的各种产品维护其运营,协助工作。计算机给人们的学习、生活、工作带来很大便利的同时,也可以大大提高各行业的经济效益和社会效益。而在教育事业的发展也是不容忽视的,衡量学生进退的法宝大多是以考生参加考试为主,而对于高校庞大的学生数量,考务管理工作变得愈来愈
8、复杂和繁重,需要花费大量的人力,精力去处理和安排。因此,毫无疑问,利用计算机技术实现智能化安排,是最为省时和高效的。考务管理系统正是基于这个出发点而开发的。1.2 开发意义首先应该看到计算机技术在各行业领域中应用的巨大作用,它不仅可以替代人工进行许多繁杂的劳动,节省许多资源,提高工作效率,还可以使敏感文档更加安全。在高校信息管理中,如何实现管理手段现代化,及时、准确的完成大量信息的分析处理,这个问题迫在眉睫。因此,建立一个自动化信息处理系统,结合学校实际,通过校园网资源,实现资源共享。既可以方便的管理学校的考务信息,又可以逐步从手工操作的模式中脱离出来,提高工作效率的同时,又方便了广大师生及时
9、了解考务咨询。该系统为学生、老师提高基本信息查询,成绩查询,考试查询等方面的信息资料。在此之上系统提供考场安排,座位安排,考试公告管理,学生、教师信息管理等系统管理功能,对老师,学生信息进行动态管理,考场灵活布置,免去人为安排,处理的繁琐。减轻工作强度,把考务管理工作从繁重重复的劳动中解放出来。2 系统设计要求2.1 系统需求分析2.1.1 任务概述该考务管理系统主要是对高校考务信息进行管理,方便高校考场安排工作,方便学生、教师考试信息查询,减少信息管理的工作量。系统开发中要考虑的重要约束是考场安排冲突检测问题。主要有:a) 同一个班级的同学考试时,务必同坐一个教室;b) 同一个班级,不可以同
10、时进行两门以上的考试;c) 参加同一门课程考试的所有班级必须安排在同一时间考;d) 同一个考场不能同时被占用。2.2 设计要求2.2.1 系统设计目标考务管理系统以学生、老师为主要服务对象,核心开发思想是实现考场安排,以考务管理为核心,提供多种形式的考务信息查询功能。为了达到预期的效果,最基本的要求是系统能够运行起来,实现资源共享,辅助高校处理考务管理工作,优化资源配置,实现管理现代化、信息化的目的。2.2.2 系统设计原则(1)先进性和实用性相结合的原则:信息技术的飞速发展,要求系统的设计必须具有先进性,体现管理思想的先进,使用业务功能的先进和技术的先进,此外,要从用户的使用环境出发,做到先
11、进性与实用性相结合。(2)安全性和稳定性原则:系统中包涵有个人重要信息,系统在设计和实现时需充分考虑诸如信息的保密性、访问的可控性、数据的完整性、系统的冗余性等安全可靠性因素;系统运行应稳定可靠,当发生突发性故障,如掉电、非法操作等时,系统在故障排除后能自动将数据恢复到故障前的状态。(3)可扩充性、易维护性和易操作性原则:为了方便今后系统的升级,要求系统设计结构要合理,余留相应升级接口。系统运行难免会出错,这时应考虑出错系统的设置和处理。系统应该具有友好的用户界面设计,方便用户使用,提供在线技术支持。2.3 系统可行性分析2.3.1 经济可行性分析本系统开发所使用的软件都是免费的,硬件要求也不
12、是很高,目前高校中很多学生都已拥有个人 PC,并且接入校园网,所以开发投入和使用耗资都是极少的,因此开发系统在经济上是完全可行的。2.3.2 操作可行性分析大多数高校学生早已使用过微软的 Windows 操作平台,而考务管理系统正是基于微软 Windows 操作平台来开发的客户端,相信在学过计算机基础的同学们眼中,熟悉这样一个简单的系统是件非常容易的事。而且本系统友好的用户界面设计,能够引导用户很快地掌握系统的使用方法。2.3.3 技术可行性分析本系统使用 Microsoft Visual Studio 2008、Microsoft SQL Server 2005、Office2007 等软件
13、,结合 C# 、ASP.NET 技术进行开发,都是微软的产品,软件友好、操作简单的用户界面一直得到业界开发人员的好评。所以这样的结合无疑是较为成功的解决方案。Microsoft SQL Server 2005 数据库不会像ORACLE 那样耗资源,在于高校这种数据量不是巨大的环境下足以应付。而ASP.NET 是目前 B/S 模式中较为流行的技术,稳定性也很好,技术支持资料容易查找,所以在技术实现上应该是相对容易的。2.4 系统参与者描述学生:系统服务对象,学生可以通过系统查看与考试相关的各种信息、进行成绩查询等。教师:系统服务对象,教师可以通过系统对学生的个人信息,成绩信息,试卷信息进行编辑、
14、修改等。管理员:系统最高权限持有者,可以编辑和老师、学生相关的各种信息,如考场安排,监考老师安排,考试时间安排等。2.5 系统用例图根据调查和分析画出如下的系统用例图:、 、 、 、 、 、 、 、 、 、 、 、 、 、 、 、 、 、 、 、 、 、 、 、 、 、 、 、 、 、 、 、 、 、 、 、 、 、 、 、 、 、 、 、 、 、 、 、 、 、 、 、 、 、 、 、 、 、 、 、 、 、图 12.6 系统功能要求描述根据用例图把系统分为三个主要模块,即:学生模块、教师模块、管理员模块。2.6.1 学生模块该模块包括查看公告,查询考试安排,查询考试成绩,查看个人信息,给老
15、师留言等,功能描述如下:(1)查看公告学生登录系统后可以查看系统公布的最新考试相关公告,在公告列表页点击标题后,转到详细内容页。(2)查询考试安排学生可以根据考试课程或者是考试时间进行考试安排查询,若没有输入条件点击提交,系统会给出提示信息。(3)给老师留言若是学生想有话对老师讲,可以在这里给老师留言,选择要留言的老师,可以看到他人的留言,点击我要留言按钮后,可以编辑自己的留言。(4)查询考试成绩学生可以根据输入的课程名称查询考试成绩,若是没有成绩,则系统给出相应提示信息。(5)查看个人信息学生在这里可以修改自己的信息,如联系电话,住址等(除学号、姓名外) 。2.6.2 教师模块该模块包括查看
16、公告,查看监考安排,编辑考试成绩,编辑学生信息,查看个人信息,查看留言等,功能描述如下:(1)查看公告该部分功能与学生模块一致。(2)查看监考任务教师登录系统后,点击查看监考任务,进入到监考查询页面,可以根据条件查询(按姓名,按时间)监考任务。系统没有安排监考的情况下会给出提示信息。(3)编辑考试成绩教师评卷后在这里可以给参加考试的学生录入成绩。(4)查看留言在这里教师可以查看学生给自己的留言,同时也可以回复学生的留言。(5)查看个人信息教师在这里可以查看个信息。2.6.3 管理员模块该模块包涵的功能有:学生信息管理,教师信息管理,学院信息管理,班级信息管理,课程信息管理,教程信息管理,教室信
17、息管理,管理员信息管理,公告管理,考场安排管理。(1)学生信息管理包括学生个人信息的增加、删除、修改。(2)教师信息管理包括对老师个人信息的增加、删除、修改。(3)学院信息管理包括对学院信息的增加、删除、修改。(4)班级信息管理包括对班级信息的增加、删除、修改。(5)课程信息管理包括对课程信息的增加、删除、修改。(6)教程信息管理包括对教程信息的增加、删除、修改。(7)教室信息管理包括对教室信息的增加、删除、修改。(8)管理员信息管理包括对管理员信息的增加、删除、修改。(9)公告信息管理包括对公告信息的增加、删除、修改。(10)考场信息管理这里主要实现考场的安排,包括各种冲突检测与排除的实现,
18、整理出完整的考场安排计划表。3 系统开发环境和工具从用户使用方便的角度出发,该系统在 window 环境下,使用C#、ASP.NET 技术,利用 Microsoft Visual Studio 2008 结合 SQL SERVER 2005进行开发,绘图工具主要使用 StarUML,Visio 2007。4 系统详细设计4.1 系统功能模块设计根据需求分析画出如下的功能设计图:图 24.2 数据库表设计结合功能设计图,根据数据库设计的实体完整性,参照完整性,用户定义后台管理 教师模块 学生模块教师学生信息教学信息考务相关教师监考查询成绩管理查看留言个人中心考试安排查询成绩查询给教师留言个人中心
19、查看公告查询考试安排考场安排资源状态查询考试公告管理考务管理系统完整性原则,从数据库运行效率出发,建立表之间的关联,提高查询速率。 将数据库各表设计如下:学生表:student该表设置学生编号 sno 为主键,方便与班级表 class,成绩表 sc,角色表 role 建立关联。具体字段如下:列名 数据类型 允许为空 说明sno int 不允许 学号,主键ssex char(2) 允许 性别stell varchar(10) 允许 电话saddress varchar(50) 允许 地址classno int 允许 班级编号,外键roleno int 允许 角色编号 ,外键spass varch
20、ar(10) 允许 密码课程表:course该表以课程编号 cno 作为主键。列名 数据类型 允许为空 说明cno Int 不允许 课程编号、主键cname Varchar(50) 允许 课程名称班级表:class该表以班级标号 classno 作为主键,学院编号 dno 作为外键与学院表进行关联。列名 数据类型 允许为空 说明classno int 不允许 班级编号、主键classname varchar(50) 允许 班级名称ccount int 允许 班级人数dno int 允许 学院编号,外键课程安排表:planning该表以班级编号、考场编号作为主键。列名 数据类型 允许为空 说明c
21、lassno int 不允许 班级编号、主键之一cno int 不允许 课程编号、主键之一studytime numeric(4,0) 允许 学时教室表:room该表以教室编号 roomno 为 key,与考场安排 test 表关联列名 数据类型 允许为空 说明roomno int 不允许 教室编号,主键roomname varchar(50) 允许 教室名称seats numeric(4,0) 允许 座位数教师表:teacher该表以教师编号 tno 为 key,以学院编号 dno、角色编号 roleno 为外键,与学院表、角色表存在关联。列名 数据类型 允许为空 说明tno int 不允许
22、 教师编号,主键tname varchar(10) 允许 教师名称tprof varchar(10) 允许 职称ttell varchar(10) 允许 联系电话tpass varchar(10) 允许 密码dno int 允许 学院编号,外键roleno int 允许 角色编号,外键教程安排表:teaching列名 数据类型 允许为空 说明cno int 不允许 课程编号,主键之一tno int 不允许 教师编号,主键之一createtime datetime 允许 创建时间成绩表:sc列名 数据类型 允许为空 说明sno int 不允许 学生编号,主键之一cno int 不允许 课程编号,
23、主键之一score decimal(4,0) 允许 分数学院表:department列名 数据类型 允许为空 说明dno int 不允许 学院编号,主键dleader varchar(10) 允许 领导名称dtell nchar(10) 允许 学院电话dname varchar(20) 允许 学院名称学生留言表:message列名 数据类型 允许为空 说明messageno int 不允许 留言编号,主键mcontent nvarchar(50) 允许 留言内容ntime datetime 允许 留言时间tno int 允许 教师编号,留言时间角色表:role列名 数据类型 允许为空 说明ro
24、leno int 不允许 角色编号,主键rolecontent nvarchar 允许 角色说明管理员表:manager列名 数据类型 允许为空 说明mno int 不允许 管理员编号,主键mname varchar(10) 允许 管理员姓名mpass varchar(10) 允许 管理员密码roleno int 不允许 角色编号,外键公告表:news列名 数据类型 允许为空 说明nno int 不允许 公告编号,主键ncontent nvarchar(50) 允许 公告内容ntitle varchar(20) 允许 公告标题4.3 系统主要模块设计4.3.1 考场安排模块该模块主要根据任务陈
25、述中考场安排约束条件进行考场安排。用户只需选择学院,课程及指定一个考试时间,系统便可根据选择的学院,课程,时间进行自动考场安排。具体安排步骤如下:a) 用户选择一个学院,选择一门课程,指定一个时间(如,数计学院,C#程序设计,2011-4-30 上午) ;b) 系统根据指定的课程,查找选修了该门课程的班级,并给将数据显示予用户(可以是单个班级信息,也可能是多个班级信息) ;c) 用户点击安排按钮,系统根据提供的信息,开始查询符合条件的资源进行安排;d) 系统检测冲突,首先检测时间是否相同,根据时间检测结果进行下一步操作,e 或者 f;e) 若时间相同检测班级,根据班级检测结果进行下一步 g 或
26、 h,f) 若时间不同,则显示安排结果,给出成功提示;g) 若班级冲突,则提示冲突原因,及操作提示;h) 若班级不冲突,检测考场是否冲突,根据检测结果进行下一步 i 或j;i) 若考场冲突,则提示冲突原因,及操作提示。j) 若考场不冲突,则检测监考老师是否冲突,根据结果进行下一步 k或 l;k) 若监考老师冲突,则提示冲突原因,及操作提示;l) 若监考老师不冲突,则提示考场安排成功。该过程的流程图如下:此外系统还支持,资源查询,如剩余考场数,未安排班级等。4.3.2 考场安排查询模块该模块为用户提供多种查询方式进行考场安排查询,用户可以根据需要,进行选择查询。提供的选择条件有:学院、班级、课程
27、、时间、考场、监考老师,提供的排序方式有根据按时间,按班级编号,按考场编号。用户可以根据列出的条件进行组合查询,当系统有满足条件的记录时,给出相应记录,若是用户没有选择任何条件,那么系统则把所有记录数呈现。图 3第 1 步取 c n a m e开始执行第 0步第 2 步得到c l a s s n o判断时间是否存在相同否第 3 步取班级人数第 4 步取考场第 5 步指定监考第 6 步退出是给出提示该课程的某班级已经安排 , 请另选时间判断是否有相同的c l a s s n o 已经安排是否第 3 步取班级人数判断是否有相同的考场已被占用第 4 步取考场第 5 步指定监考否是判断是否有同一老师被
28、安排同时监考的情况否否是5 系统的实现5.1 系统部署图节 点 1M o d e l . d l l D A L . d l l B L L . d l l节 点 2W e b管理员教师用户学生用户图 45.2 系统人机交互设计系统考场查询模块人机交互设计:输入本次考场查询命令:输出提示信息;for 检测用户输入的查询条件;if 满足考场的条件存在;then 打印符合条件的考场信息;else 打印所有考场信息;end for;打印查询结果,及提示信息(结果是否为输入条件的结果)5.3 SQL Server 2005 服务器中使用存储过程 存储过程不仅可以重复使用,同时还可以提高查询速率,提高性
29、能。系统考场查询模块的设计就是用存储过程处理的;代码如下:CREATE PROCEDURE ProSearchTest dno int, -学院编号classno int,-班级编号testtime varchar(50),-考试时间roomno int,-考场编号tno int,-监考老师编号cno int-课程编号AS begin select * from test1where (dno=dno or dno is null)and (classno=classno or classno is null)and (testtime=testtime or testtime=)and (r
30、oomno=roomno or roomno is null)and (tno1=tno or tno is null or tno2=tno)and (cno=cno or cno is null)endGO6 系统功能测试主要对系统各功能模块进行黑盒测试,例如:1登录模块,当用输入错误的用户名和密码是,禁止登入,同时能够给出相关提示信息;2剩余资源查询模块,选择录入搜索信息,能提供正确的资源剩余情况。3系统稳定性测试,当系统访问量达到一定量时,是否能运行正常,及运行速度是否减慢。7 总结考务管理系统的开发,使得高校考务管理工作逐渐从手动劳动的环境中脱离出来,方便高校考务管理的同时提高了工作效率,实现了考场的智能化安排。然而受个人技术的局限性,系统在某些方面(如画面美化设计、效率问题考虑)还有待改进。通过这个系统的开发让我学到了很多以前没有用过的知识,如一些联动效果,无刷新效果,存储过程的技术等等,同时,锻炼了自己的独立思考能力和实际操作能力。参考文献1 庞哑娟 孙明丽 吕继迪 ASP 技术方案宝典,北京:人民邮电出版社 2008.2 关涛 CSS 从入门到精通,北京:化学工业出版社 2009.3 陈伟 编 SQL Server 2005 数据库应用开发教程 北京:清华大学出版社,2005.4 肖刚 古辉 程振波 张元鸣 实用软件文档写作,北京:清华大学出版社,2009.