当前位置: 首页 > 编程笔记 >

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

怀晋
2023-03-14
本文向大家介绍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项目实战之在线考试系统的实现(系统介绍),希望对大家有所帮助!

 类似资料:
  • 主要内容:1 Swing实现在线考试项目1 Swing实现在线考试项目 在此项目中,有10个问题要做。我们使用Java数组来存储问题,选项和答案,而不是数据库。您可以使用List集合或数据库代替数组。 输出结果为:

  • 本文将从 SPI Flash 和 SD Card 两方面给大家讲解如何使用文件系统,以及针对本次 DIY 做出的一些优化,会大大增强系统性能。 本次任务 了解 RT-Thread 文件系统,在接收节点中使用文件系统,存放来自发送节点发送过来的数据。 上述任务比较单一,只是文件系统而已。不过,能巧妙灵活的把文件系统用好用对,可不是一件轻松的事情。 RT-Thread 文件系统简要介绍 DFS 是 R

  • 讲师:gh0stkey 整理:飞龙 协议:CC BY-NC-SA 4.0 概述 官网:http://www.jeedaa.com/ 主要产品有: 捷达ERP 捷达OA 捷达eHR 捷达CRM 捷达eFax 捷达仓库管理 捷达进销存.Net 捷达协同办公.Net 均存在能够 GetShell 的漏洞。 这个东西仍旧是闭源的,我们使用它的演示站点,http://demoerp.jeedaa.com来进

  • 本文向大家介绍java实现选课系统,包括了java实现选课系统的使用技巧和注意事项,需要的朋友参考一下 本文实例为大家分享了java实现选课系统的具体代码,供大家参考,具体内容如下 这个程序主要是练习IO(文件读写,序列化),集合框架的使用 学生端可以实现,查找课程,增加选课,删除选课的功能 管理端可以实现对备选课程,学生信息的增删查改 缺点:登陆操作没有实现密码验证和多态。           

  • 本文向大家介绍java实现门禁系统,包括了java实现门禁系统的使用技巧和注意事项,需要的朋友参考一下 本文实例为大家分享了java实现门禁系统的具体代码,供大家参考,具体内容如下 Door.java Computer.java Amind.java Employee.java Guest.java Validate.java FingVId.java PasswordVId.java Test.

  • 本文向大家介绍python实现名片管理系统项目,包括了python实现名片管理系统项目的使用技巧和注意事项,需要的朋友参考一下 名片管理系统,供大家参考,具体内容如下 环境要求:linux系统、python2.x或python3.x 资源地址:GitHub地址 写在前面的话:笔者之前在初学C/C++时,都曾写过类似的管理系统。这次使用Python来书写这个管理系统,深刻地感受到python对程序员

  • 问题内容: 我需要一个“系统”函数调用,与Python,Perl,PHP,Ruby和&c相同。当它在Rhino JavaScript引擎上运行时,它将成为名为Narwhal的JavaScript标准库的组件,而Rhino JavaScript引擎又在Java上运行。 问题在于Java的标准库似乎已经抽象出了生成共享父进程的stdio的子进程的能力。这意味着您不能将交互性推迟到子流程中。 我的第一个

  • 目前常用的 Linux 发行版主要包括 Debian/Ubuntu 系列和 CentOS/Fedora 系列。 前者以自带软件包版本较新而出名;后者则宣称运行更稳定一些。选择哪个操作系统取决于读者的具体需求。 使用 Docker,读者只需要一个命令就能快速获取一个 Linux 发行版镜像,这是以往包括各种虚拟化技术都难以实现的。这些镜像一般都很精简,但是可以支持完整 Linux 系统的大部分功能。