试题库管理系统本科毕业设计.doc_第1页
试题库管理系统本科毕业设计.doc_第2页
试题库管理系统本科毕业设计.doc_第3页
试题库管理系统本科毕业设计.doc_第4页
试题库管理系统本科毕业设计.doc_第5页
已阅读5页,还剩55页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

试题库管理系统本科毕业设计目 录引 言1第一章 绪论21.1 工程研究的背景与意义21.1.1 工程研究的背景21.1.2工程研究的意义21.2研究现状以及研究内容21.2.1研究现状21.2.2研究内容3第二章 系统实现相关技术42.1开发框架技术42.2 数据库技术42.2.1 数据库42.2.2 SQL语句42.2.3 ORM52.3 Ajax技术52.4 开发环境52.5 可行性分析6第三章 系统需求分析73.1 系统功能用例图73.1.1 用户73.1.2 教师73.1.3 管理员83.2 系统功能时序图93.2.1 教师模块时序图93.2.2 管理员模块时序图103.3 逻辑模型11第四章 系统设计16 4.1 系统功能的结构设计164.1.1 总体结构设计164.1.2 教师模块结构设计174.1.3 管理员模块结构设计184.2逻辑结构设计204.2.1 用户信息表204.2.2 角色表214.2.3 系部表214.2.4 专业表224.2.5 科目表224.2.6 章节表234.2.7 难度系数表234.2.8 单选题表244.2.9 多选题表254.2.10 判断题表254.2.11填空题表264.2.12简答题表274.2.13 试卷标题信息表284.2.14 单选试题表284.2.15多选试题表294.2.16 其它试题表304.2.17 试卷表304.3程序流程图314.3.1 系统前台模块流程图314.3.2 系统后台模块流程图324.4程序核心模块设计334.4.1登录模块334.4.2编辑个人资料344.4.3修改密码354.4.4试题模块354.4.5试卷模块364.5接口394.5.1 系统首页394.5.2 系统前台界面404.5.3 系统后台界面47 第五章 系统测试515.1软件测试的目的与原则515.2 测试分类515.3 测试用例515.4系统调试时遇到的问题及解决方法52 结 论54参考文献55谢 辞57引 言现如今,计算机的广泛运用已经普及到千家万户,随着网络的飞速发展,但是教学软件的开发还依旧处于发展的低端,为了满足用户,在最短时间求得利益最大化,所以试题库管理系统的实现很有必要,试题库管理最核心的环节是试题和试卷模块,其中最难实现的是试卷模块,虽然已经步入网络时代,但是在我国,大多数教学任务还是使用传统方式完成的,比如在考试前,教师手忙脚乱的找题,究竟哪道题才是考试的重点,在找题和选题中绞尽脑汁,最后还得组织并且写成纸质版进行初审,浪费不少时间和精力,并且也不方便进行修改,人们也迫切希望使用计算机取代人工出题,从而减少教师工作量,提高效率,教师所做的仅仅是维护试题库,而不用手持一摞书,只需要一台计算机,一套完整的试卷就会呈现出来,经济性也是相当可观的。本文对试题库管理系统进行了完整的论述,深入描述了该系统从设计到实现的整个过程,文章的基本结构如下:第一章:绪论部分。主要阐述了工程研究的背景以及意义、研究现状以及研究内容。第二章:相关技术部分。主要叙述了实现该系统用到的开发框架技术、数据库技术、Ajax技术、开发环境、可行性分析等内容。第三章:需求分析部分。主要通过用例图、时序图说明该系统具有的功能模块,并且通过系统的逻辑模型来说明实体类之间的关系,以及各个实体拥有的属性。第四章:系统设计部分。该部分是本系统的关键章节,将系统的概要设计和详细设计合并为一部分进行描述,主要有系统功能的结构设计,通过系统的功能模块图进行该系统的模块讲解;接下来还叙述了该系统的逻辑结构设计,主要是对实现该系统用到的数据库表进行分析;通过绘制程序流程图对每一个用户操作流程进行说明,然后讲解了该系统实现的核心模块的输入、输出,采用的算法思想等;最后通过图片来显示系统的良好接口。第五章:系统测试。该章节主要描述了软件测试的目的与原则、测试的分类、测试用例以及系统调试时遇到的问题及解决方法等内容。第六章:结论。该部分简单介绍了系统存在的缺陷以及对该系统的展望。第一章 绪论1.1 工程研究的背景与意义1.1.1 工程研究的背景面对教育、教学的现代化建设,考试也是必须完成的一项工作,而考试的核心部分是试题库的建设,如果没有试题库管理系统的支持,试题的存在也毫无意义,在整个考试的过程中,试题扮演着重要的角色,我们可以这么认为,试题库管理系统是在线考试、在线评分的支撑平台,如果这个平台搭建不好,或者实现不够完整,将会给后续的组卷、测试带来一定的影响,试题库中由于试题种类多,数据比较庞大,常规管理将会面临浪费时间、管理不便的问题,为了克服种种问题,把这一切交给具有强大功能的计算机来完成,从而达到更新方便、快速查找、组卷灵活,同时也降低了人员的工作强度,在计算机还未应用到各大高校中,试卷都是由教师或者工作人员管理,寻找试题或者亲自出题来组成试卷,最后提供给学生使用,近几年随着计算机在高校的普及使用,硬件设施发展颇快,考试系统是各大高校必不可少的,通过计算机来有效管理,方便师生,更是一种节约纸张的选择,日积月累积攒了一大笔财富。1.1.2工程研究的意义试题库管理系统为学校能方便快捷的举行考试,其效果与真实考试一样,不论在出题还是组卷,其内容主要有前台和后台的开发,后台主要实现数据库的维护,供管理员使用,前台主要完成试题和试卷模块,供教师使用,这样做可以为教师节省大量时间,减轻工作量,提高效率,也可以作为高校方便教师使用的一种出卷工具。1.2研究现状以及研究内容1.2.1研究现状时代的发展,社会的进步,生活水平的提升,计算机越来越深入到我们的学习、工作、生活中,成为我们不可缺少的辅助工作,我们被它的强大功能所征服,深入到各行各业,利用它可以完成图像处理、文件传送、学习、娱乐。尤其网络学习,可以带给我们无穷多的知识,在学校,学习是学生的天职,考试也是自我检测的关键,试卷也是必备品。谈起试卷,传统的出卷方式,老师们必须提前花费时间和精力才能组出一份满意的试卷,比如说要预先考虑出所有试题的难度系数,所有题型,这是一个比较复杂的过程。一个好的试题库管理系统,要求友好的界面,以及操作方便,容易录题,试题库维护简单,更新容易,组卷灵活快捷,能迅速找到自己想要的试题,还应该具备一定的安全性。1.2.2研究内容该试题库管理系统的主要内容:1)用户登录模块:(验证用户的合法性,有教师、管理员二种不同类型的用户,登录成功后进入相应的页面进行操作)。2)用户管理模块:(添加操作用户、条件查询用户信息、修改用户信息、注销用户等基本操作)。3)试题库管理模块:(按题型管理,有多种题型,包括单选题、多选题、填空题、判断题、简答题五种题型,分别对应有增、删、改、查功能)。4)试卷管理模块:(实现试卷的手动生成或者根据条件系统随机自动生成,可以进行预览,老师预览是带有答案的试卷)。5)角色管理模块:(角色的增加、删除、修改操作)。6)系部管理模块:(管理员可以继续增加系部、修改、删除等操作)7)专业管理模块:(管理员可以根据系部进行专业的分配,可以根据系部查询该系部所对应的专业)8)科目管理模块:(管理员可以根据系部和专业分配科目,可以根据系部和专业查询该专业拥有的科目)。9)个人资料管理模块:(教师和用户可以查询个人资料,可以修改个人资料,也可以修改密码)10)退出系统:(用户成功退出系统)。第二章 系统实现相关技术本章节对试题库管理系统应用的技术做简单介绍,主要针对该系统用到开发框架、数据库、Ajax、JavaScript等技术方面的介绍。2.1开发框架技术 该系统采用的是三大框架SSH,也是目前比较流行的Web应用程序开发框架,第一个S代表的是Struts,第二个S代表Spring,H代表Hibernate,SSH为Struts + Spring + Hibernate的一个集成框架,它主要有四层:表示层、业务逻辑层、数据库持久层、域模块层,这样划分的蕴意在于给开发人员一个清晰的开发思路,并且后期维护相对操作简单。Struts负责的是整体的基础架构,主要分离MVC。Spring主要管理Struts和Hibernate,具体实现思路是:用面向对象的方法根据需求提出一些模型,将这些模型封装成基本的Java对象,然后采用Hibernate架构编写DAO层,通过DAO实现实体类与数据库之间的访问和转换。2.2 数据库技术2.2.1 数据库该系统采用的是MySQL数据库,由瑞典MySQL AB开发,目前属于Oracle公司,在Web应用方面,MySQL是最好的关系数据库管理系统应用软件之一,一般用于小型系统,灵活性比较好。2.2.2 SQL语句SQL(Structure Query Language,结构化查询语言),是计算机专用的数据库语言,无论是哪一个数据库,都可以是用SQL语言来访问和修改数据库的内容,并且都遵循ASNI,即美国国家标准协会制定的SQL标准,SQL语言对于初学者比较容易理解,并且使用起来也相对灵活,SQL语言不但可以对数据库信息进行查询,而且还可以对数据库信息添加、删除、修改以及跳转等操作。2.2.3 ORMORM代表关系映射,是一种程序技术,主要用于实现面向对象语言中不同类型数据库之间的转换,ORM的三个原则:易于理解性:以最基本的形式建模数据。简答传达性:容易被多数人理解。描述精确性:运用标准的语言创建结构。2.3 Ajax技术Ajax是一种异步请求技术,它的核心是JavaScript、XMLHTTPRequest和DOM对象,系统通过JavaScript向服务器提出请求并做出响应,在这个过程中并不影响用户做别的操作。Ajax的工作原理其实相当于在用户端和服务器端加了一个中间层,并不是所有用户的请求都直接交给服务器端完成,有的像一些数据验证和数据处理都交给中间层去完成,只有确定用户向服务器读取新的数据时,这时中间层才会向服务器端真正提出请求。利用Ajax技术有许多优点,比如:无需刷新更新数据,让Web应用程序与用户做出敏捷的交互,用户不用花费很长时间去等待,有良好的用户体验;它采用的是异步方式与服务器进行通信,不干涉用户的其他操作,优化了浏览器与服务器的沟通,减少多余的数据传输、在一定程度上减少了一定的流量损耗;前端与后端负载平衡,客户端可以为服务器端分担工作,Ajax是按照需求取数据,在很大程度上减少了对服务器端冗余的请求和响应;Ajax的另外一个优点是界面与应用分离,有利于分工合作,以免修改页面造成Web应用程序的错误。同时Ajax也存在一些弊端,比如:使用了Ajax,如果想要撤销一步工作,不可能实现,只能重新运行;其次是对搜索引擎支持较弱,如果不恰当使用,会增加数据流量的消耗,从而降低整个系统的性能;Ajax另一个缺点是使用Ajax实现的技术网站,在某些手机上是打不开的。2.4 开发环境试题库管理系统是在Eclipse 环境下开发的Web应用程序,服务器采用的是Apache Tomcat 7.0版本。Eclipse是基于Java的开放源代码的、可扩展的开发平台,附带了一个Java开发组件集,即(Java Development Kit,JDK),虽然Eclipse 是使用Java语言开发的,但是它的用途不仅局限于Java开发语言,也可以支持C或者C+等开发语言。Apache Tomcat 7.0是一个单独的Web服务器,它是由Apache基金会下属的Jakarta项目开发的Servlet容器,实现了对Servlet和Jsp技术的支持,并且提供了Web服务器一些特有的功能。2.5 可行性分析首先,浅谈技术可行性。本系统仅需要一台装有浏览器的计算机即可,对机器本身没有太高的要求,目前大多数高校或者笔记本电脑等基本都可以满足要求。现在软件技术逐步走向成熟道路,软件技术更是毋庸置疑。其次,再谈经济可行性。装好该系统即可使用,实现本系统的成本主要集中在软件的开发上,当系统正式投入运行后可以为学校节约不可忽略的费用,所带来的经济效益远超过开发成本,在经济上是完全可行的。最后,操作可行性。界面设计简答大方,背景颜色选取适合该管理系统,并且充分考虑了教师的操作习惯,数据的插入、存储、表的设计符合规范,统计准确,为后期系统维护奠定了基础第三章 系统需求分析随着高校的规模逐步扩大,教学任务也随之加大,教师的工作量也不断加大,面对平时的模拟考试,老师还得选题、出题,工作量无意中加大了许多。计算机实现“试题库管理系统”比人工手动选题、出题,在人力和物力方面都节省了不少资源。基于Web试题库管理系统的设计可以有效解决高校教师选题、出卷中现存的问题,管理起来方便、快捷,教师可以学生进行经常性考核,减轻老师工作力度的同时,学生的成绩也有了相应的提高,所以,实现该试题库管理系统是很有必要的。3.1 系统功能用例图3.1.1 用户管理员、教师统称为用户。图3-1 用户用例图3.1.2 教师教师首先根据管理员分配给的用户名和密码进行登录,登录成功才可以进行章节管理、试题管理、试卷管理操作,也可以选择退出系统,对于个人信息模块,如教师初次登录,个人信息只有用户名和密码,其他个人资料根据自己所需进行补充完善。图3-2教师用例图3.1.3 管理员管理员想要对该系统进行操作,首先登录该系统,然后可以进行角色管理、用户管理、系部管理、专业管理、科目管理、个人信息管理,也可以选择退出系统。图3-3 管理员用例图3.2 系统功能时序图3.2.1 教师模块时序图用户输入合法的用户名和密码进行登录,通过调用数据库数据进行和页面输入值比对,如果登录失败给出相应的提示,登录成功则跳入相应的页面,可以选择任意一个模块进行操作,具体时序图如下:图3-4教师模块时序图3.2.2 管理员模块时序图用户输入合法的用户名和密码进行登录,通过调用数据库数据进行和页面输入值比对,如果登录失败给出相应的提示,登录成功则跳入相应的页面,可以选择任意一个模块进行操作,具体时序图如下:图3-5管理员模块时序图(1)图3-6管理员模块时序图(2)3.3 逻辑模型通过前文所述,根据整个系统的模块分析,该系统E-R图如下所示:图3-7试题库管理系统E-R图通过对整个系统设计的数据进行准确分析,得出的实体类分为十种,具体描述如下图:图3-8用户实体E-R图图3-9 角色实体E-R图图3-10 系部实体E-R图图3-11 专业实体E-R图图3-12 科目实体E-R图图3-13 难度系数实体E-R图图3-14单选题实体E-R图图3-15多选题实体E-R图注:其他试题包含判断题、填空题、简答题三种题型图3-16 其他试题试题E-R图图3-17试卷标题实体E-R图图3-18试卷实体E-R图第四章 系统设计4.1 系统功能的结构设计4.1.1 总体结构设计图4-1 试题库管理系统结构图功能说明:根据上述试题库管理系统的结构图可以看出该系统的主要核心模块是试题管理和试卷管理。试题管理主要是对单选题、多选题、判断题、填空题、简答题的操作。试卷管理主要是手动组卷、自动组卷、我的试卷管理和最终的试卷预览。当对试题或者试卷进行操作时,可以根据系统中已经初始化好的数据进行选择,也可以进行条件查询。4.1.2 教师模块结构设计图4-2教师功能模块图功能说明:对于教师模块,首先用户根据管理员授予的用户名和密码进行登录。如果用户名、密码输入与之不符,登录失败,会弹出小窗口予以提示登录失败信息。然后用户可以再次填写登录信息,或者取消登录;如果用户名、密码输入正确,则成功跳转到教师操作页面,该教师拥有教师权限的所有功能,具体功能如下:个人资料管理:对于初次登录的用户只拥有用户名和密码,其他个人信息一律为空,用户可以根据自己所需进行完善,一旦信息填写不当,可以对个人信息进行修改为了安全,也可以修改密码,用户名是不允许修改的。试题管理:试题管理模块主要是按题型进行管理,有五种题型,分别有单选题模块、多选题模块、判断题模块、填空题模块、简答题模块,每一个模块,可以对相应题型有录题、查询、修改、删除等操作。当教师进行试题录入时首先选择系部、专业、科目、章节,然后进行试题信息的填写。教师可以根据系部、专业、科目、章节进行条件查询,以免重复录题。教师如果发现试题库中某道试题存在问题,可以对试题进行及时修改。教师如果发现试题库中的某些试题已经过时,可以分别进行试题删除。试卷管理:试卷管理模块主要拥有手动组卷、自动组卷、我的试卷管理、试卷最终预览功能。手动组卷时首先录入试卷标题信息,然后跳转到我的试卷模块,进行试卷中每一种试题的添加操作,试题的添加有两种方式,教师可以从试题库中选择添加,也可以教师自己出卷,如果试题添加有误,可以进行修改操作,也可以进行删除操作;自动组卷调用系统函数,产生一个随机数,根据随机数与数据库中试卷标题编号进行匹配,然后根据试卷标题编号显示出某套试卷;教师如果觉得这套试卷有不合理之处,可以对试卷进行修改,不需要的试题可以进行删除操作,最后教师可以进行试卷最终的一个预览,教师预览是附有答案的试卷。章节管理:教师可以根据科目来确定每本书中拥有的章节,有录入章节、编辑章节、删除章节等操作。教师进行章节录入时,首先要选择系部、专业、科目,最后进行章节信息的录入,当发现科目章节有重复时,可以对科目进行修改,也可以删除章节。退出系统:用户可以点击右上方的退出系统链接,成功退出系统。4.1.3 管理员模块结构设计图4-3管理员模块图功能说明:对于管理员模块,该用户拥有该系统的最高权限,该用户输入自己专属的用户名和密码进行登录。如果用户名、密码输入与之不符,登录失败,会弹出小窗口予以提示登录失败信息。然后用户可以再次填写登录信息,或者取消登录;如果用户名、密码输入正确,则成功跳转到管理员操作页面,该用户拥有管理员权限的所有功能,具体功能如下:个人资料管理:对于初次登录的用户只拥有用户名和密码,其他个人信息一律为空,用户可以根据自己所需进行完善,也可以修改个人信息,为了安全,可以修改密码,用户名是不允许修改的。系部管理:系部管理主要对系部的录入、系部信息显示、修改系部、删除系部操作。如果该高校缺少某个系部,管理员可以增加系部,如:软件工程系、计算机系等;如果某高校发现系部有所变化,或者改系部不存在时,管理员可以修改系部、删除系部等操作。专业管理:专业管理旨在对专业信息的录入、专业列表显示、专业的编辑、删除等操作。如果某高校增加某一专业,管理员首先选择系部,然后进行专业的录入,如果专业填写有误,可以修改专业,也可以删除专业重新录入。科目管理:科目管理主要有添加科目、科目信息显示、修改科目、删除科目等操作。如果某高校的某一专业增加某一科目,管理员首先选择系部、选择专业、然后进行科目的录入,如果科目填写有误,可以修改专业,也可以删除专业重新录入。角色管理:目前该系统角色有两种,教师、管理员,后期如果对该系统继续补充,可以对角色进行操作,增加角色、角色列表、角色编辑与删除等操作。用户管理:管理员可以管理用户,如果该学校新增教师,需要操作该系统,管理员有权增加用户、用户信息列表显示、修改用户、注销非法用户。难度系数管理:管理员可以对难度系数进行管理,如:增加难度系数、修改难度系数、删除难度系数等操作。这样教师操作时可以直接调用后台数据库信息进行选择添加难度系数。退出系统:用户可以点击右上方的退出系统链接,成功退出系统。4.2逻辑结构设计4.2.1 用户信息表 用户表主要用来存放用户信息,数据库中表名为userinfo,主键是用户ID,该表由用户编号、用户名、密码、性别、真实姓名、职称、联系方式、邮箱、角色编号9个字段组成。表4-1用户信息表数据表名称userinfo中文名称用户信息表主键userId序号字段名称中文名称类型及长度其它说明1userId用户IDint Not null主键(0)系统自动递增(从1开始递增)2userName用户名varchar(8)Not null唯一3password密码varchar(13)Not null密码最大是13位,最少是6位4sex性别char(2)Not null男 女5realName真实姓名varchar(20)Not null唯一6position职称varchar(6)Not null讲师/教授/副教授7phone联系方式varchar(13)8email邮箱varchar(50)Not null9roleId角色idintNot null4.2.2 角色表角色表主要用来存放角色信息,数据库中表名为role,主键是角色ID,该表由角色ID、角色名称2个字段组成。表4-2角色表数据表名称role中文名称角色表主键roleId序号字段名称中文名称类型及长度其它说明1roleId角色IDintNot null主键(0)系统自动递增(从1开始)2roleName角色名varchar(10)Not null唯一4.2.3 系部表系部表主要用来存放系部信息,数据库中表的命名为department,主键为系部ID,该表由系部ID、系部名称2个组成。表4-3系部表数据表名称department中文名称系部表主键deptId序号字段名称中文名称类型及长度其它说明1deptId系部idIntNot null(0)系统自动递增2deptName系部名称varchar(20)Not null唯一4.2.4 专业表专业表主要用来存放专业信息,在数据库中表的名称是major,主键是专业编号,外键是系部编号,该表主要有专业编号、专业名称、系部编号3个字段组成。表4-4专业表数据表名称major中文名称专业表主键定义majorId序号字段名称中文名称类型及长度其它说明1majorId专业编号IntNot null(0)系统自动递增2majorName专业名称varchar(30)Not null3deptId系部编号IntNot null外键4.2.5 科目表科目表主要用来存放科目信息,在数据库该表的名称是course,主键是科目编号,有2个外键分别是系部编号和专业编号,该表主要有科目编号、科目名称、系部编号、专业编号4个字段组成。表4-5科目表数据表名称course中文名称科目表主键定义courseId序号字段名称中文名称类型及长度其它说明1courseId科目idintNot null(0)系统自增递增2courseName科目名称varchar(30)Not null3deptId系部idIntNot null外键4majorId专业idintNot null外键4.2.6 章节表章节表主要用来存放章节信息,该表在数据库中定义为chapter,主键是章节编号,有3个外键字段,分别是系部编号、专业编号、科目编号,该表由章节编号、章节名称、系部编号、专业编号、科目编号5个字段组成。表4-6章节表数据表名称chapter中文名称章节表主键定义chapterId序号字段名称中文名称类型及长度其它说明1chapterId章节idintNot null(0)系统自动递增2chapterName章节名varchar(10)Not null3deptId系部idintNot null外键4majorId专业idintNot null外键5courseId科目idintNot null外键4.2.7 难度系数表难度系数表主要用来存放难度系数信息,该表在数据库中表名是difficulty,该表的主键是难度系数编号,由难度系数编号、难度系数2个字段组成。表4-7难度系数表数据表名称difficulty中文名称难度系数表主键定义difficultyId序号字段名称中文名称类型及长度其它说明1difficultyId难度idintNot null自动递增2difficultyRatio难度系数intNot null4.2.8 单选题表单选题表主要存放单选题信息,该表在数据库中的命名为selection,该表的主键是单选题编号,有5个外键,分别是系部编号、专业编号、科目编号、章节编号、难度系数编号,该表由单选题编号、单选题名称、系部编号、专业编号、科目编号、章节编号、难度系数编号、问题、选项A、选项B、选项C、选项D、答案等13个字段组成。表4-8 单选题表数据表名称selection中文名称单选题表主键定义selectId序号字段名称中文名称类型及长度其它说明1selectId单选题编号intNot null(0)系统自动递增2selectName单选题名称varchar(100)Not null3deptId系部编号intNot null外键4majorId专业编号intNot null外键5courseId科目编号intNot null外键6chapterId章节编号intNot nul外键7question问题varchar(100)Not nul8a选项Avarchar(100)Not nul9b选项Bvarchar(100)Not nul10c选项Cvarchar(100)Not nul11d选项Dvarchar(100)Not nul12answer答案Varchar(100)Not null13difficultyId难度idintNot null外键4.2.9 多选题表多选题表主要存放多选题信息,在数据库中表的命名为manyselection,该表的主键是多选题编号,有5个外键,分别是系部编号、专业编号、科目编号、章节编号、难度系数编号,该表由单选题编号、单选题名称、系部编号、专业编号、科目编号、章节编号、难度系数编号、问题、选项A、选项B、选项C、选项D、选项E、答案等14个字段组成。表4-9多选题表数据表名称manyselection中文名称多选题表主键定义manySelectId序号字段名称中文名称类型及长度其它说明1manySelectId单选题编号intNot null(0)系统自动递增2manySelectName单选题名称varchar(100)Not null3deptId系部编号intNot null外键4majorId专业编号intNot null外键5courseId科目编号intNot null外键6chapterId章节编号intNot nul外键7question问题varchar(100)Not nul8a选项Avarchar(100)Not nul9b选项Bvarchar(100)Not nul10c选项Cvarchar(100)Not nul11d选项Dvarchar(100)Not nul12e选项Evarchar(100)13answer答案Varchar(100)Not null14difficultyId难度系数编号intNot null外键4.2.10 判断题表判断题表主要存放判断题信息,在数据库中表的命名为judge,该表的主键是判断题编号,有5个外键,分别是系部编号、专业编号、科目编号、章节编号、难度系数编号,该表由判断题编号、判断题名称、系部编号、专业编号、科目编号、章节编号、难度系数编号、问题、答案等9个字段组成。表4-10 判断题表数据表名称judge中文名称判断题表主键定义judgeId序号字段名称中文名称类型及长度其它说明1judgeId判断题编号intNot null(0)系统自动递增2judgeName判断题名称varchar(100)Not null3deptId系部编号intNot null外键4majorId专业编号intNot null外键5courseId科目编号intNot null外键6chapterId章节编号intNot nul外键7question问题varchar(100)Not nul8answer答案Varchar(100)Not null9difficultyId难度系数编号intNot null外键4.2.11填空题表填空题表主要存放填空题信息,在数据库中表的命名为fillingblacks,该表的主键是填空题编号,有5个外键,分别是系部编号、专业编号、科目编号、章节编号、难度系数编号,该表由填空题编号、填空题名称、系部编号、专业编号、科目编号、章节编号、难度系数编号、问题、答案等9个字段组成。表4-11 填空题表数据表名称fillingblacks中文名称判断题表主键定义fillingId序号字段名称中文名称类型及长度其它说明1fillingId填空题编号intNot null(0)系统自动递增2judgeName填空题名称varchar(100)Not null3deptId系部编号intNot null外键4majorId专业编号intNot null外键5courseId科目编号intNot null外键6chapterId章节编号intNot nul外键7question问题varchar(100)Not nul8answer答案Varchar(100)Not null9difficultyId难度系数编号intNot null外键(续 表) 4.2.12简答题表简答题表主要存放简答题信息,在数据库中表的命名为question,该表的主键是简答题编号,有5个外键,分别是系部编号、专业编号、科目编号、章节编号、难度系数编号,该表由简答题编号、简答题名称、系部编号、专业编号、科目编号、章节编号、难度系数编号、问题、答案等9个字段组成。表4-12 简答题表数据表名称question中文名称判断题表主键定义questionId序号字段名称中文名称类型及长度其它说明1questionId简答题编号intNot null(0)系统自动递增2questionName简答题名称varchar(100)Not null3deptId系部编号intNot null外键4majorId专业编号intNot null外键5courseId科目编号intNot null外键6chapterId章节编号intNot nul外键7question问题varchar(100)Not nul8answer答案Varchar(100)Not null9difficultyId难度系数编号intNot null外键4.2.13 试卷标题信息表试卷标题表主要存放试卷表题信息,在数据库中表的命名为titleexam,该表的主键是试卷标题编号,有5个外键,分别是系部编号、专业编号、科目编号、章节编号、用户编号,该表由试卷标题编号、试卷标题名称、系部编号、专业编号、科目编号、章节编号、用户编号、出卷时间、考试时长、总分等10个字段组成。表4-13试卷标题信息表数据表名称titleexam中文名称试卷标题表主键定义titleId序号字段名称中文名称类型及长度其它说明1titleId试卷标题编号intNot null(0)系统自动递增2titleName试卷标题varcha(30)Not null3deptId系部编号IntNot null外键4majorId专业编号intNot null外键5courseId科目编号intNot null外键6chaptersId章节编号intNot null外键7userId用户编号intNot null外键8OnDate出卷时间dateNot null9duration考试时长double Not null10sum总分doubleNot null4.2.14 单选试题表单选试题表主要存放试卷中的单选试题信息,该表在数据库中的命名为selectexam,该表的主键是单选试题编号,有2个外键,分别是试卷标题编号、难度系数编号,该表由单选试题编号、试卷标题编号、试题分值、难度系数编号、问题、选项A、选项B、选项C、选项D、答案等10个字段组成。表4-14单选试题表数据表名称selectexam中文名称单选试题表主键定义id序号字段名称中文名称类型及长度其它说明1id单选题编号intNot null(0)系统自动递增2titleId试卷标题编号varchar(100)Not null外键3score试题分值floatNot null4question问题varchar(100)Not nul5a选项Avarchar(100)Not nul6b选项Bvarchar(100)Not nul7c选项Cvarchar(100)Not nul8d选项Dvarchar(100)Not nul9answer答案Varchar(100)Not null10difficultyId难度idintNot null外键4.2.15多选试题表多选试题表主要存放试卷中的多选试题信息,该表在数据库中的命名为manyselectexam,该表的主键是单选试题编号,有2个外键,分别是试卷标题编号、难度系数编号,该表由多选试题编号、试卷标题编号、试题分值、难度系数编号、问题、选项A、选项B、选项C、选项D、选项E、答案等11个字段组成。表4-15多选试题表数据表名称manyselectexam中文名称多选试题表主键定义id序号字段名称中文名称类型及长度其它说明1id单选题编号intNot null(0)系统自动递增2titleId试卷标题编号varchar(100)Not null外键3score试题分值floatNot null4question问题varchar(100)Not nul(续 表) 5a选项Avarchar(100)Not nul6b选项Bvarchar(100)Not nul7c选项Cvarchar(100)Not nul8d选项Dvarchar(100)Not nul9e选项Evarchar(100)Not nul10answer答案Varchar(100)Not null11difficultyId难度idintNot null外键4.2.16 其它试题表其它试题表主要存放试卷中的判断试题、填空试题、简答试题信息,该表在数据库中的命名为otherexams,该表的主键是其它试题编号,有2个外键,分别是试卷标题编号、难度系数编号,该表由其它试题编号、试卷标题编号、试题分值、难度系数编号、问题、答案、试题类型编号等7个字段组成。表4-16其它试题表数据表名称manyselectexam中文名称其它试题表主键定义id序号字段名称中文名称类型及长度其它说明1id单选题编号intNot null(0)系统自动递增2titleId试卷标题编号varchar(100)Not null外键3score试题分值floatNot null4question问题varchar(100)Not nul5answer答案Varchar(100)Not null6difficultyId难度系数编号intNot null外键7typeId试题类型编号intNot null4.2.17 试卷表试卷表主要存放试卷信息,该表在数据库中的命名为paper,该表的主键是试卷编号,有4个外键,分别是试卷标题编号、单选试题编号、多选试题编号、其他试题编号,该表由试卷编号、试卷标题编号、单选试题编号、多选试题编号、其他试题编号等5个字段组成。表4-17 试卷表数据表名称paper中文名称试卷表主键定义id序号字段名称中文名称类型及长度其它说明1id试卷编号intNot null(0)系统自动递增2titleId试卷标题编号intNot null外键3selectId单选试题编号intNot null外键4manySelectId多选试题编号intNot nul外键5otherId其它试题编号intNot null外键 4.3程序流程图4.3.1 系统前台模块流程图试题库管理系统前台模块流程图如下:图4-4系统前台流程图4.3.2 系统后台模块流程图试题库管理系统后台模块流程图如下:图4-5系统后台模块流程图4.4程序核心模块设计4.4.1登录模块1)功能描述为使用该系统的所有用户提供的登录功能,用户需要在此登录界面输入用户名、密码,系统将会根据数据库信息是否匹配进行验证,如果用户名、密码输入正确,系统将会根据用户角色编号判断该用户属于哪一类用户,并且跳转到相应的主界面进行进一步操作。2)登录模块输入、输出表4-18登录模块项目输入、输出模块输入输出登录模块用户名密码提示错误信息页面成功跳转3)算法思想(1)用户在登录页面输入用户名、密码,并且点击“登录按钮”。(2)在UserAction中系统将会通过UserService层找到与数据库相连接的UserDao层将页面值与数据库值进行比较。(3)如果该用户对象为空,页面不进行跳转,并且提示“用户登录失败,请确认后重新登录”;否则根据用户角色编号进行判断,如果角色编号为1,该用户属于教师,则跳转到教师显示主页面。如果角色编号为2,该用户属于管理员,则跳转到管理员线束主页面。4.4.2编辑个人资料1)功能描述该系统的用户首次登录时个人信息只包含用户名、密码,其他信息根据个人需要进行补充完善,进行编辑个人资料,

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论