毕业设计论文基于C的自动出卷系统的设计与实现.doc
-
资源ID:4888011
资源大小:353.52KB
全文页数:27页
- 资源格式: DOC
下载积分:10金币
友情提示
2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
|
毕业设计论文基于C的自动出卷系统的设计与实现.doc
- 27 -第一章 引言1.1系统基本功能描述伴随着当今世界知识经济的迅猛发展,计算机已经普遍应用于社会的各个领域,并且扮演着越来越重要的角色。计算机的普及与应用在一定程度上已经作为衡量一个国家或地区的发达或发展程度的标志。在这样的大环境下,我们当代的大学生就应该掌握并应用好计算机。作为计算机专业的学生,就更应该熟练掌握计算机专业技术知识,成为计算机领域的先锋。理想是远大的,道路并非坦途!理解、掌握计算机专业的基础知识是目前我们所能触及到的最现实的目标。学校教务管理工作中一项非常重要的工作就是考试管理工作,每学期各专业考试,从组织出卷到试卷的印制及试卷的管理等工作非常繁琐且工作量很大,这种组织管理方式不仅工作任务繁重而且试卷的标准化程度、难易程度、题量大小等各方面难以控制,难以形成有效的试题库,不利于充分发挥历年来的优秀试题及试卷的作用,给试题和试卷的管理带来很多问题和困难。鉴于这种情况,利用计算机进行试卷的自动生成并逐步积累形成有效的试题库,对试题和试卷的管理将变的高效而便捷,对提高工作效率,使试卷管理逐步走向正规化自动化将起到十分重要的作用。 本系统的目标是:形成试题库并能够按预定要求自动生成试卷。让老师在传道授业的过程中可以更方便的得到帮助和支持,及时得到教学的反馈。让广大同学在考试中可以理解自己的不足之处,更透彻,更自如的掌握学习的主动权。此外, 试题库也是本系统的一个重要的目标,试题可由历年的试卷提供,也可随时补充新搜集的试题及题型,逐步完善形成试题库系统并提供随机检索试题的各种必要的方法。第二章 开发环境及工具简介2.1 开发工具C# 2.1.1 C#简介Visual C#(读作“C sharp”)是 Visual Studio .NET 中引入的一种新的编程语言。C# 从 C 和 C+ 演变而来,是一种简单、现代、类型安全和面向对象的语言。设计 C# 是为了建立运行于 .NET 平台上的、范围广泛的企业级应用程序。用 Visual C# 编写的代码被编译为托管代码,这意味着它将受益于公共语言运行库的服务。这些服务包括:语言互操作性、垃圾回收、增强的安全性以及改进的版本支持。在Visual Studio .NET 中,Visual C# 完全得到项目模板、设计器、属性页、代码助理、对象模型和其他开发环境功能的支持。Visual C# 编程的库是 .NET Framework。C#在带来对应用程序的快速开发能力的同时,并没有牺牲C与C+程序员所关心的各种特性。它忠实地继承了C和C+的优点。如果你对C或C+有所了解,你会发现它是那样的熟悉。即使你是一位新手,C#也不会给你带来任何其它的麻烦,快速应用程序开发(Rapid Application Development,RAD)的思想与简洁的语法将会使你迅速成为一名熟练的开发人员。 正如前文所述,C#是专门为.NET应用而开发出的语言。这从根本上保证了C#与.NET框架的完美结合。在.NET运行库的支持下,.NET框架的各种优点在C#中表现得淋漓尽致。2.1.2 C#特点(1)简洁的语法:C#语言中完全没有了指针,在C+中常见的语法冗余的问题,比如“const”和“denfine”、各种各样的字符类型等,C#对此进行了简化。把别的冗余形式从他的语法结构中清除出去。(2)精心的面向对象设计:除了面向对象语言应有的特征:封装、集成与多态性;C#中的每种类型都可以看作一个对象,且只允许单继承,避免了类型定义的混乱;C#中的函数、变量、常数等都必须封装在一个类中,加强了可读性。(3)与Web的紧密结合:SOAP的使用使得C#克服了一些开发工具不能与Web紧密结合这一缺陷,大规模深层次的分布式开发从此成为可能。(4)完整的安全性与错误处理:C#的先进设计思想可以消除软件开发中的许多常见错误,并提供了包括类型安全在内的完整的安全性能。C#会帮助开发者通过更少的代码完成相同的功能,这不但减轻了编程人员的工作量,同时更有效地避免了错误的发生。(5)版本处理技术:C#提供内置的版本支持来减少开发费用,使用C#将会使开发人员更加轻易地开发和维护各种商业用户。(6)灵活性与兼容性:在简化语法的同时,C#并没有失去灵活性。尽管它不是一种无限制语言,比如:它不能用来开发硬件驱动程序,在默认的状态下没有指针等等。2.2 SQL SERVER 20052.2.1 SQL SERVER 2005简介MICROSOFT SQL SERVER是运行在NT操作系统上的、基于客户机/服务器的关系型数据库管理系统。SQL SERVER使用客户机/服务器结构,把工作负荷分解成分别在服务器上和客户机上执行的任务。客户机应用程序可以运行在一个或多个客户机机器上,也可以运行在服务器上,负责向用户提供数据;服务器负责管理和分配服务器资源。它为企业中的用户提供了一个安全、可靠和高效的平台用于企业数据管理和商业智能应用。SQL Server 2005 为IT专家和信息工作者带来了强大的、熟悉的工具,同时减少了在从移动设备到企业数据系统的多平台上创建、部署、管理及使用企业数据和分析应用程序的复杂度。 通过全面的功能集、和现有系统的集成性、以及对日常任务的自动化管理能力,SQL Server 2005 为不同规模的企业提供了一个完整的数据解决方案。SQL Server 数据平台包括以下工具:·关系型数据库: 安全、可靠、可伸缩、高可用的关系型数据库引擎,提升了性能且支持结构化和非结构化(XML)数据。 ·复制服务: 数据复制可用于数据分发、处理移动数据应用、系统高可用、企业报表解决方案的后备数据可伸缩存储、与异构系统的集成等,包括已有的Oracle数据库等。 ·通知服务: 用于开发、部署可伸缩应用程序的先进的通知服务能够向不同的连接和移动设备发布个性化、及时的信息更新。 ·集成服务: 可以支持数据仓库和企业范围内数据集成的抽取、转换和装载能力。 ·分析服务: 联机分析处理(OLAP)功能可用于多维存储的大量、复杂的数据集的快速高级分析。 ·报表服务: 全面的报表解决方案,可创建、管理和发布传统的、可打印的报表和交互的、基于Web的报表。 ·管理工具: SQL Server 包含的集成管理工具可用于高级数据库管理和调谐,它也和其他微软工具,如MOM和SMS紧密集成在一起。标准数据访问协议大大减少了SQL Server和现有系统间数据集成所花的时间。此外,构建于SQL Server内的内嵌Web service支持确保了和其他应用及平台的互操作能力。 ·开发工具: SQL Server 为数据库引擎、数据抽取、转换和装载(ETL)、数据挖掘、OLAP和报表提供了和Microsoft Visual Studio® 相集成的开发工具,以实现端到端的应用程序开发能力。SQL Server中每个主要的子系统都有自己的对象模型和API,能够以任何方式将数据系统扩展到不同的商业环境中。2.2.2 SQL SERVER 2005 的特点MICROSOFT SQL SERVER 2005 数据库管理系统可以满足各种类型不同用户和独立软件供应商商业程序的要求,可以说,MICROSOFT SQL SERVER 2005是面向21世纪的关系型数据库,它在易用性、伸缩性、可靠性和数据仓库等方面都具有优良的性能。SQL Server 2005的突出特征如下:* 全面重新设计的DTS体系结构和工具,* 引入了由管理工具和管理应用编程接口(API)组成的集成化套件用以降低操作的复杂度,* 主要改进包括表分区、增强复制功能和64位支持特性,* 允许使用任何Microsoft .NET语言开发数据库对象的能力,* 增添新的XML数据类型,* 新增查询类型和在事务中进行错误处理的能力。2.3 软硬件要求为了保证系统运行的效率和可靠性,系统服务器端应具有较高的软硬件配置,客户端的要求不是很高。将后台数据库与业务系统相结合,可以建立在同一个的机器上,也可以把数据库服务器和业务服务器分别建立在不同的机器上。软件要求 操作系统:WINDOWS XP 数据库:Microsoft SQL Server 2005 开发工具:Visual Studio2005硬件要求 机型:CELERON366以上硬盘:40GB内存:256MB显示器:VGA第三章 自动出卷系统分析3.1系统基本功能描述自动出卷系统的设计是为了实现高校教师按照课程的进度,出相关试卷来检验学生的掌握程度,形成良好的教学反馈,因此设置了对数据库试题库进行试题的增加、查询、删除等试题管理功能,对试卷进行按照难度系数、题型题量来分配分值进行试卷的生成的试卷管理功能。3.2 可行性分析本系统的可行性分析包括以下几个方面的内容:3.2.1技术可行性由于C#是专门为.NET应用而开发出的语言。这从根本上保证了C#与.NET框架的完美结合。在.NET运行库的支持下,.NET框架的各种优点在C#中表现得淋漓尽致。因此在熟悉了C#这一高端语言后,可为软件的编写提供极大的便利,且更易看易懂。Sql server 数据库和C#技术的结合,可以开发出实用、简便、高效的自动出卷系统。因此技术上是可以实现的。3.2.2经济可行性本系统采用SQL Server 2005和C#语言作为主要开发工具,所需使用的资源仅限于计算机、软件等,资源损耗较少,但开发出的系统却能够为教师节省工作时间,提高工作效率,带来更大的经济效益。因此在经济上是可行的。3.2.3运行可行性本系统为一个小型的教师自动出卷系统,所耗费的资源非常的小,学校的电脑无论是硬件方面还是软件方面都能够满足条件,因此,本系统在运行上是可运行的、可操作的。3.3 系统需求分析3.3.1 识别参与者通过对系统需求进行分析,对这一独立的自行设计软件,可以确定系统的用户仅为教师,教师严格按照系统的要求指示完成试卷的录入生成。3.3.2 识别用例前面已经识别了参与者,通过对需求的进一步分析,可以确定系统中有如下的示例存在:(1)试题管理:提供了教师对试题库各类科目、题型的试题增加、查询、删除的功能。(2)试卷管理:提供了教师对相应科目试卷难度系数选取、题型题量的选取、分配分值在D盘目录下自动生成一份3.3.3系统用例图我们建立系统用例图来识别参与者和用例之间的关系如图3-1所示系统试题管理出卷管理(教师) (学生)3.3.4 业务流程分析(1) 试题管理:提供了对数据库按照相关试题信息添加试题、按各题型整体查询试题、输入ID号删除你不需要的试题的功能(2) 出卷管理:指定试卷难度系数,按照各类题型题量分配分值, 生成一份100分的试卷在D:目录下。(3) 帮助:提供了对整个系统进行帮助的功能。(4) 退出:退出系统模块。相关试题信息登陆教师试题管理试题库完整信息试卷信息学生教师试卷录入系统总体业务流程图第四章系统设计4.1 数据库设计4.1.1 概念结构设计1.系统涉及到的实体自动出卷系统中所涉及的主要实体及其属性有:(1) 登陆用户用户名,密码(2) 语文选择题ID,试题内容,选项A,选项B,选项C,选项D,标准答案,难度系数(3) 语文判断题ID,试题内容,标准答案,难度系数4 语文简答题ID,试题内容,参考答案,难度系数(5) 数学选择题ID,试题内容,选项A,选项B,选项C,选项D,标准答案,难度系数(6) 数学判断题ID,试题内容,标准答案,难度系数(7) 数学简答题ID,试题内容,参考答案,难度系数2E-R模型如图41所示。标准答案标准答案标准答案ID数学简答题试题内容难度系数ID数学选择题试题内容难度系数ID选项D选项C选项B选项A数学选择题试题内容难度系数ID语文简答题试题内容难度系数ID语文选择题试题内容难度系数ID选项D选项C选项B选项A语文选择题密码试题内容难度系数用户名用户标准答案标准答案标准答案4.1.2 逻辑结构设计逻辑数据库设计的目的是从概念模型导出特定的DBMS可以处理的数据库的逻辑结构,这些模式在功能、性能、完整性和一致性约束及数据库可扩充性等方面均应满足用户提出的要求。根据对数据库的需求分析,以及数据库的E-R图的设计,将数据关系在表中实现,完成系统数据库建表工作。主要表结构如下:表1 用户表说明字段名数据类型字段长度用户名IDVarchar220密码passwordVarchar220表2 语文选择题表说明字段名数据类型字段长度编号IDVarchar24试题内容contentVarchar22048选项AAVarchar250选项BBVarchar250选项CCVarchar250选项DDVarchar250标准答案StdanswerVarchar250难度系数DifficultyVarchar22表3 语文判断题表说明字段名数据类型字段长度编号IDVarchar24试题内容contentVarchar22048标准答案StdanswerVarchar250难度系数DifficultyVarchar22表4 语文简答题表说明字段名数据类型字段长度编号IDVarchar24试题内容contentVarchar22048参考答案RefanswerVarchar22048难度系数DifficultyVarchar22表5 数学选择题表说明字段名数据类型字段长度编号IDVarchar24试题内容contentVarchar22048选项AAVarchar250选项BBVarchar250选项CCVarchar250选项DDVarchar250标准答案StdanswerVarchar250难度系数DifficultyVarchar22表6 数学判断题表说明字段名数据类型字段长度编号IDVarchar24试题内容contentVarchar22048标准答案StdanswerVarchar250难度系数DifficultyVarchar22表7 数学简答题表说明字段名数据类型字段长度编号IDVarchar24试题内容contentVarchar22048参考答案RefanswerVarchar22048难度系数DifficultyVarchar224.2系统模块设计模块设计的主要方法是结构化方法,主导思想是以系统的逻辑功能设计和数据流关系为基础,采用“自顶向下,逐步求精”的设计方法,将本系统分解为功能明确,易于修改,大小适中的模块结构。 本系统主要分为三大模块:登录模块、试题管理模块、试卷管理模块。系统各模块功能图如下所示:试题删除试题增加试题查询用户登陆退出试题管理试卷管理登陆自动出卷系统试卷生成试卷难度选取试卷题型选取系统功能模块图具体功能模块描述如下:1、系统登陆模块其模块包括:登录系统、退出系统登录系统:允许用户输入用户帐户及密码,提交后,系统查询数据库验证身份分配权限。教师身份可以对整个数据表进行管理。修改用户、退出系统可在数据库中进行修改。2、试题管理模块此模块有包括三个子模块:增加试题、查询试题、删除试题。(1) 增加试题从数据资料中选取需要的试题,按试题ID,试题内容,4个选项,标准答案试题,难度系数分类严格填入,输入完后提交,后可继续添加试题,可在相应数据库表中查询验证。如果填写时有空缺会提示相应错误。(2) 查询试题可以从选择、判断、简答等几种不同题型任选其一进行整体查询,试题将按照ID号依次排序供查询。(3)删除试题查看数据库表格,如果有不需要试题,打开此模块,逐次输入需要删除的试题ID,提交确定。如果有误则说明数据库表格中没有相应ID号的试题,提示查看确定后重新输入。3试卷生成模块(1) 试卷难度选取按高、中、低难度系数选取,从数据库中相应数据表中提取选定难度系数题目。(2) 题型题量选取相应题型中输入适当题量,不超过相应题库容量(100)。(3)试卷生成试题选取完成后,系统自动分配适当分值,合成100分试卷,在D盘目录下生成试卷。第五章 系统实现本系统是针对于大学学院的教师出卷的管理,主要面向的用户对象是学校教师,负责人。此系统的主要包括有:试题管理、试卷生成、数据库查询等几大部分,其中试卷生成是本系统的核心模块。下面对各模块进行具体介绍。5.1 登陆模块5.1.1 登陆界面设计在登陆页面Login中,按数据库给定ID,Password输入用户名、密码,如想修改这些信息,在数据表UserInf中修改,登陆时用户名、密码不能为空,否则会提示“用户名/密码不能为空”,当输入信息错误时,会提示“用户名/密码不正确,请重新输入!”5.1.2 流程图设计5.2 试题管理模块此模块共分了语文、数学的选择、判断、简答题型的增加,查询,删除等子模块。此模块是试卷生成模块的基础,数据库内容的管理在此模块中实现,注意的是在每次关闭数据库时都需断开数据库连接。5.2.1试题增加5.2.1.1 试题增加界面设计试题增加的时候主键ID号不能相同,否则会提示操作失败信息,各Text框都不能为空,接下来对所获得的数据进行预处理更新,最后关闭数据库连接5.2.1.2 试题增加流程图设计5.2.1试题查询5.2.2.1 试题查询界面设计单击需要查询题型Button,在TEXT框中显示数据库中所有相关试题库。5.2.2.2 试题查询流程图设计5.2.1试题删除5.2.3.1 试题删除界面设计输入需要删除试题的ID号,如相关表中存在该试题,提示删除成功,否则提示出错信息5.2.3.2 试题删除流程图设计5.3试卷生成模块5.3.1 试卷生成界面设计随机选取表中N道所需题型、题量、难度系数的试题,排序后文件输出流到D盘目录examout.txt文档中。5.3.2 试卷生成流程图设计随即数返回需要试题量ID数组方法,ID号不重复5.4 帮助模块帮助模块提供系统帮助与系统信息,其中系统帮助与具体的帮助信息文件联系在一起,选择该菜单项后,将打开“帮助”窗体;选择“系统信息”菜单项后,弹出有关系统信息的窗体;或者选择“关于”菜单项后,弹出关于系统名称的窗体。 总结和讨论自动出卷系统是一个对试题进行管理,试卷进行生成的系统。在本系统中,使用C#和SQL Server 2005数据库设计制作自动出卷系统。本系统的各个功能模块部分只是实现了基本的功能,但如果想真正把它用到高校试题信息管理中,还需要大家对系统进行进一步的完善工作,以便能更好的适应需要。 通过这次毕业设计,我对C#和数据库方面的知识有了进一步的认识,尤其是数据传输过程的使用。本系统由于整个系统完全都是由个人设计制作的,因此在开发过程中遇到了许多问题和难点。系统的许多细节问题主要是靠查阅资料、实践摸索实现的,有些不能独立解决的问题,是指导老师的耐心细致的指导帮助我解决的,加之本人水平有限,并没有完完全全体现出面向对象的强大功能,而且还存在着许多不足之处。如: 一些数据输入时没有及时的进行数据校验,不能保证数据的绝对正确性。 由于时间关系,系统功能实现不够完善,使用不是很方便,比如,没有实现多条记录的删除和添加以及数据的导入等功能,数据恢复技术也尚未实现。总之,本系统还有许多地方有待改进,本人将继续学习新知识、新技术,不断改进和完善系统。希望有朝一日,它能为高校所用,给师生带来便利。由于系统开发经验不足,时间有限,虽然我在有限时间里顺利的完成了系统的分析、设计和调试的基本工作,但是仍然有许多不足之处,我会在将来的软件设计过程中引以为戒。主要参考文献1 Koril Walcon 等著C#入门经典(第三版)2006年 清华大学出版社 。2 明日科技 编著C#数据库系统开发完全手册2006年12 月1日 人民邮电出版社。3 Koril Walcon 等著C#高级编程(第三版)2005年 清华大学出版社 。4 (美)马歇尔 著,许华杰,刘光惠 译Visual C#2005技术内幕 2007-1-1 清华大学出版社。5 丁士锋 等编著Visual C#2005+SQL Server 2005数据库与网络开发2008-1-1电子工业出版社。6郑宇军,C#2.0程序设计教程,清华大学出版社,2005.7美Geetanjali Arora 等著 C#专业项目实例开发 中国水利水电出版社 2003 8萨师煊 王珊 编著 数据库系统概论 第三版 北京 高等教育出版社 20009 张立 编著 C#2.0宝典北京:电子工业出版社 200710 曹祖圣 吴名哲 黄世阳、林义证Visual C# .NET程序设计经典北京:科学出版社 2004