热门标签 | HotTags
当前位置:  开发笔记 > 后端 > 正文

Java项目实战之在线考试系统的实现(系统介绍)

这篇文章主要介绍了Java项目实战之在线考试系统的实现(系统介绍),本文通过实例代码,截图的形式给大家展示系统技术架构,需要的朋友可以参考下

1.本系统和现在有的考试系统有以下几种优势:

a.和现在有的系统比较起来,本系统有科目、章节、老师、学生、班级等信息的管理,还有批阅试卷查看已批阅试卷等。传统的考试系统划分并不细,业务功能简单。 b.和学校的考试系统还有外面的考试系统比较起来,本系统是B/S结构,学校的考试系统一般为C/S结构,性能方面不如B/S结构,并且C/S接口需要安装客户端,客户端压力很大,我的系统只需要电脑具有浏览器,在同一局域网就可以进行考试。 c.从架构方面来讲,我们的系统为分布式架构,传统的考试系统没有我们的架构合理。

2.在线考试系统技术架构

主要技术
Spring、SpringMVC、Mybatis
JSP、JSTL、jQuery、HTML、CSS、JS
Mysql
bootstrap
开发工具和环境
Eclipse
Maven
Tomcat 7
JDK 1.8
Mysql 5.6
Win10 操作系统
传统架构
传统考试系统采用该架构

这里写图片描述 

分布式架构

本系统采用分布式架构

这里写图片描述

3.系统功能介绍

这里写图片描述

4.本系统数据库表关系

/*为了方便查询,所以不满足范式要求,但是查询效率很高*/
/*因为表特别多,因此表之间的结构关系就不在详细说明了*/
-- 管理员
CREATE TABLE `admin` (
 `id` varchar(20) NOT NULL COMMENT '管理员账号id',
 `NAME` varchar(20) NOT NULL COMMENT '姓名',
 `sex` varchar(2) NOT NULL COMMENT '性别',
 `age` int(11) DEFAULT NULL COMMENT '年龄',
 `idcard` varchar(20) NOT NULL COMMENT '身份证号',
 `phone` varchar(20) NOT NULL COMMENT '手机号',
 `QQ` varchar(20) DEFAULT NULL COMMENT 'QQ',
 `emai` varchar(20) DEFAULT NULL COMMENT '邮箱',
 `PASSWORD` varchar(20) DEFAULT NULL COMMENT '密码',
 PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8
-- 老师
CREATE TABLE `teacher` (
 `id` varchar(20) NOT NULL,
 `NAME` varchar(20) NOT NULL,
 `sex` varchar(2) NOT NULL,
 `age` int(11) DEFAULT NULL,
 `idcard` varchar(20) NOT NULL,
 `phone` varchar(20) NOT NULL,
 `QQ` varchar(20) DEFAULT NULL,
 `email` varchar(20) DEFAULT NULL,
 `PASSWORD` varchar(20) DEFAULT NULL,
 PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8
-- 学生
CREATE TABLE `student` (
 `id` varchar(20) NOT NULL,
 `classesId` int(11) DEFAULT NULL,
 `name` varchar(20) NOT NULL,
 `sex` varchar(2) NOT NULL,
 `age` int(11) DEFAULT NULL,
 `idcard` varchar(20) NOT NULL,
 `phone` varchar(20) NOT NULL,
 `QQ` varchar(20) DEFAULT NULL,
 `email` varchar(20) DEFAULT NULL,
 `password` varchar(20) DEFAULT NULL,
 `classesName` varchar(20) DEFAULT NULL,
 PRIMARY KEY (`id`),
 KEY `FK_studentClasses` (`classesId`),
 CONSTRAINT `FK_studentClasses` FOREIGN KEY (`classesId`) REFERENCES `classes` (`classesId`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8
-- 科目
CREATE TABLE `subject` (
 `id` int(11) NOT NULL AUTO_INCREMENT,
 `NAME` varchar(20) NOT NULL,
 PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=29 DEFAULT CHARSET=utf8
-- 章节
CREATE TABLE `chapter` (
 `id` int(11) NOT NULL AUTO_INCREMENT,
 `sub_id` int(11) NOT NULL,
 `NAME` varchar(255) DEFAULT NULL,
 `title` varchar(255) DEFAULT NULL,
 PRIMARY KEY (`id`),
 KEY `FK_subjectChaper` (`sub_id`),
 CONSTRAINT `FK_subjectChaper` FOREIGN KEY (`sub_id`) REFERENCES `subject` (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=189 DEFAULT CHARSET=utf8
--班级
CREATE TABLE `classes` (
 `classesId` int(11) NOT NULL AUTO_INCREMENT,
 `classesName` varchar(20) NOT NULL,
 `grade` varchar(20) NOT NULL,
 PRIMARY KEY (`classesId`)
) ENGINE=InnoDB AUTO_INCREMENT=6 DEFAULT CHARSET=utf8
--科目班级映射表
CREATE TABLE `subjectclasses` (
 `classesId` int(11) NOT NULL,
 `id` int(11) NOT NULL,
 PRIMARY KEY (`classesId`,`id`),
 KEY `FK_subjectClasses2` (`id`),
 CONSTRAINT `FK_subjectClasses` FOREIGN KEY (`classesId`) REFERENCES `classes` (`classesId`),
 CONSTRAINT `FK_subjectClasses2` FOREIGN KEY (`id`) REFERENCES `subject` (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8
--老师班级表
CREATE TABLE `teacher_classes` (
 `id` varchar(20) NOT NULL,
 `classesId` int(11) NOT NULL,
 `subId` int(11) NOT NULL,
 PRIMARY KEY (`id`,`classesId`,`subId`),
 KEY `FK_teacher_classes2` (`classesId`),
 KEY `FK_teacher_classes3` (`subId`),
 CONSTRAINT `FK_teacher_classes` FOREIGN KEY (`id`) REFERENCES `teacher` (`id`),
 CONSTRAINT `FK_teacher_classes2` FOREIGN KEY (`classesId`) REFERENCES `classes` (`classesId`),
 CONSTRAINT `FK_teacher_classes3` FOREIGN KEY (`subId`) REFERENCES `subject` (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8
-- 老师科目表
CREATE TABLE `teacher_subject` (
 `id` varchar(20) NOT NULL,
 `sub_id` int(11) NOT NULL,
 PRIMARY KEY (`id`,`sub_id`),
 KEY `FK_teacher_subject2` (`sub_id`),
 CONSTRAINT `FK_teacher_subject` FOREIGN KEY (`id`) REFERENCES `teacher` (`id`),
 CONSTRAINT `FK_teacher_subject2` FOREIGN KEY (`sub_id`) REFERENCES `subject` (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8
--发布考试表
CREATE TABLE `publishexam` (
 `id` int(11) NOT NULL AUTO_INCREMENT,
 `admin_id` varchar(20) NOT NULL,
 `publishTime` datetime NOT NULL,
 `subject_id` int(11) NOT NULL,
 `examTime` datetime NOT NULL,
 `description` text,
 `exam` text,
 `examType` varchar(20) DEFAULT NULL,
 `STATUS` int(11) DEFAULT NULL,
 `admin_name` varchar(20) NOT NULL,
 `subject_name` varchar(20) NOT NULL,
 `examlength` int(11) NOT NULL,
 PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=14 DEFAULT CHARSET=utf8
-- 学生考试记录表
CREATE TABLE `examhis` (
 `studentId` varchar(20) NOT NULL,
 `studentName` varchar(20) DEFAULT NULL,
 `subjectId` int(11) NOT NULL,
 `subjectName` varchar(20) DEFAULT NULL,
 `classesId` int(11) DEFAULT NULL,
 `classesName` varchar(20) DEFAULT NULL,
 `examTime` datetime NOT NULL,
 `score` int(11) DEFAULT NULL,
 `examTest` text,
 `status` int(11) NOT NULL DEFAULT '0',
 `publishExamId` int(11) NOT NULL,
 PRIMARY KEY (`studentId`,`subjectId`,`examTime`),
 CONSTRAINT `FK_stu_his` FOREIGN KEY (`studentId`) REFERENCES `student` (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8
-- 试题模块表 (选择题,填空题等)
CREATE TABLE `textmodel` (
 `id` int(11) NOT NULL AUTO_INCREMENT,
 `textType` varchar(20) NOT NULL,
 PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=5 DEFAULT CHARSET=utf8
-- 试题表
CREATE TABLE `text` (
 `id` int(11) NOT NULL AUTO_INCREMENT,
 `Tex_id` int(11) NOT NULL,
 `title` varchar(200) NOT NULL,
 `answer` varchar(200) NOT NULL,
 `diffculty` int(11) NOT NULL,
 `modelName` varchar(200) DEFAULT NULL,
 `subjectName` varchar(200) DEFAULT NULL,
 `subjectId` int(11) NOT NULL,
 `chapterId` int(11) DEFAULT NULL,
 `chapterName` varchar(200) NOT NULL,
 `type1` varchar(200) DEFAULT NULL,
 `type2` varchar(200) DEFAULT NULL,
 `type3` varchar(200) DEFAULT NULL,
 `type4` varchar(200) DEFAULT NULL,
 PRIMARY KEY (`id`),
 KEY `FK_text_type` (`Tex_id`),
 CONSTRAINT `FK_text_type` FOREIGN KEY (`Tex_id`) REFERENCES `textmodel` (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=306 DEFAULT CHARSET=utf8

5.MAVEN系统依赖和工程结构

这里写图片描述

总结

以上所述是小编给大家介绍的Java项目实战之在线考试系统的实现(系统介绍),希望对大家有所帮助!


推荐阅读
  • 从零基础到精通的前台学习路线
    随着互联网的发展,前台开发工程师成为市场上非常抢手的人才。本文介绍了从零基础到精通前台开发的学习路线,包括学习HTML、CSS、JavaScript等基础知识和常用工具的使用。通过循序渐进的学习,可以掌握前台开发的基本技能,并有能力找到一份月薪8000以上的工作。 ... [详细]
  • Java实战之电影在线观看系统的实现
    本文介绍了Java实战之电影在线观看系统的实现过程。首先对项目进行了简述,然后展示了系统的效果图。接着介绍了系统的核心代码,包括后台用户管理控制器、电影管理控制器和前台电影控制器。最后对项目的环境配置和使用的技术进行了说明,包括JSP、Spring、SpringMVC、MyBatis、html、css、JavaScript、JQuery、Ajax、layui和maven等。 ... [详细]
  • HTML5网页模板怎么加百度统计?
    本文介绍了如何在HTML5网页模板中加入百度统计,并对模板文件、css样式表、js插件库等内容进行了说明。同时还解答了关于HTML5网页模板的使用方法、表单提交、域名和空间的问题,并介绍了如何使用Visual Studio 2010创建HTML5模板。此外,还提到了使用Jquery编写美好的HTML5前端框架模板的方法,以及制作企业HTML5网站模板和支持HTML5的CMS。 ... [详细]
  • CSS3选择器的使用方法详解,提高Web开发效率和精准度
    本文详细介绍了CSS3新增的选择器方法,包括属性选择器的使用。通过CSS3选择器,可以提高Web开发的效率和精准度,使得查找元素更加方便和快捷。同时,本文还对属性选择器的各种用法进行了详细解释,并给出了相应的代码示例。通过学习本文,读者可以更好地掌握CSS3选择器的使用方法,提升自己的Web开发能力。 ... [详细]
  • 本文介绍了高校天文共享平台的开发过程中的思考和规划。该平台旨在为高校学生提供天象预报、科普知识、观测活动、图片分享等功能。文章分析了项目的技术栈选择、网站前端布局、业务流程、数据库结构等方面,并总结了项目存在的问题,如前后端未分离、代码混乱等。作者表示希望通过记录和规划,能够理清思路,进一步完善该平台。 ... [详细]
  • MySQL中的MVVC多版本并发控制机制的应用及实现
    本文介绍了MySQL中MVCC的应用及实现机制。MVCC是一种提高并发性能的技术,通过对事务内读取的内存进行处理,避免写操作堵塞读操作的并发问题。与其他数据库系统的MVCC实现机制不尽相同,MySQL的MVCC是在undolog中实现的。通过undolog可以找回数据的历史版本,提供给用户读取或在回滚时覆盖数据页上的数据。MySQL的大多数事务型存储引擎都实现了MVCC,但各自的实现机制有所不同。 ... [详细]
  • Android实战——jsoup实现网络爬虫,糗事百科项目的起步
    本文介绍了Android实战中使用jsoup实现网络爬虫的方法,以糗事百科项目为例。对于初学者来说,数据源的缺乏是做项目的最大烦恼之一。本文讲述了如何使用网络爬虫获取数据,并以糗事百科作为练手项目。同时,提到了使用jsoup需要结合前端基础知识,以及如果学过JS的话可以更轻松地使用该框架。 ... [详细]
  • 本文讨论了在shiro java配置中加入Shiro listener后启动失败的问题。作者引入了一系列jar包,并在web.xml中配置了相关内容,但启动后却无法正常运行。文章提供了具体引入的jar包和web.xml的配置内容,并指出可能的错误原因。该问题可能与jar包版本不兼容、web.xml配置错误等有关。 ... [详细]
  • 前言:关于跨域CORS1.没有跨域时,ajax默认是带cookie的2.跨域时,两种解决方案:1)服务器端在filter中配置详情:http:blog.csdn.netwzl002 ... [详细]
  • jQuery :nthchild前有无空格的区别
    :nth-child(index)子元素过滤选择器的描述是:选取每个父元素下的弟index个子元素,index从1开始。然后,我写了如下h ... [详细]
  • MVC中的自定义控件
    怎么样创建自定义控 ... [详细]
  • 本文由编程笔记#小编为大家整理,主要介绍了css回到顶部按钮相关的知识,希望对你有一定的参考价值。 ... [详细]
  • 项目需要实现弹幕,网上参考了各种方法,最后觉得transform+transition实现的效果在移动设备上性能最好,在iphone6和红米4上测试,看不到 ... [详细]
  • MVC就是model模型control控制view视图把web开发的分工明确各施其职,互不干涉在MVC模式中,三个层各施其职,所以如果一旦哪一层的需求发生了变化,就只需要更改相 ... [详细]
  • ASP.NET MVC 小牛之旅3:Routing——网址路由
    网址路由(Routing)在ASP.NETMVC中有两个主要用途,一个用途是匹配通过浏览器传来的HTTP请求,另一个用途则是响应适当的网址给浏览器。3.1匹配通过浏览器传来的HTT ... [详细]
author-avatar
宋羽翔-ben
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有