Java项目实战之在线考试系统的实现(系统介绍)
作者:灵魂_漫步 发布时间:2022-12-22 11:23:05
标签: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项目实战之在线考试系统的实现(系统介绍),希望对大家有所帮助!
来源:https://blog.csdn.net/qq_34417749/article/details/80850571


猜你喜欢
- 最近看了一些淘宝购物车的demo,于是也写了一个。效果图如下:主要代码如下: actvity中的代码:public class Shoppi
- JoinPoint的getSignature方法在使用springboot写aop的时候,有个JoinPoint类,用来获取代理类和被代理类
- 背景在 Java 中实现线程安全的传统方式是 synchronized 关键字,虽然它提供了一定的同步能力,但它在使用上
- 本文实例讲述了C#域名解析简单实现方法。分享给大家供大家参考。具体实现方法如下:using System;using System.Coll
- 最近项目需要通过经纬度查询 具体的地址和区域名称,通过查询网络资源,发现提供的大多是得到具体的地址而对区域或城市名称的获取就不是很好把握;在
- 对象重复是指对象里面的变量的值都相等,并不定是地址。list集合存储的类型是基础类型还比较好办,直接把list集合转换成set集合就会自动去
- 批注是一种富文本注释,常用于为指定的Excel单元格添加提示或附加信息。 Free Spire.XLS for Java为开发人员免费提供了
- 手动将本地jar添加到Maven仓库将jar添加到本地仓库的做法以下面pom.xml依赖的jar包为例:实际项目中pom.xml依赖写法:&
- 本文实例讲述了C#从windows剪贴板获取并显示文本内容的方法。分享给大家供大家参考。具体如下:using System;using Sy
- 摘要在使用java做后台站点的开发张,图表和报表功能都是不可或缺 的。本文推荐了8款最精彩实用的Java图表应用,大部分图表应用的功能都类似
- Qt的版本发布越来越频繁,Qt6发布已经有一段时间了,越来越多的人咨询之前的代码是否可以增加对Qt6的支持,包括开源的项目QWidgetDe
- 工作中许多代码中用到枚举(enum),更用到了需要继承的枚举,由于C#的枚举不允许被继承(但允许继承自int/float等类型,这个不是我要
- 前言我身边有一部分开发的小伙伴,存在着这样一种习惯。某一天,突然看到某一款 App 上有个很漂亮的自定义控件(动画)效果,就会绞尽脑子想办法
- springboot-dubbo cannot be cast to使用spring boot 集成dubbo的时候遇到问题:2018-05
- 一、环境准备:(根据自己电脑配置来选择安装版本,我的电脑是64位,所以此处选择64位安装)JDK下载:JDK 1.8下载地址: http:/
- 1. 支持的视图技术前端模板引擎技术的出现,使前端开发人员无需关注后端业务的具体实现,只关注自己页面的呈现效果即可,并且解决了前端代码错综复
- 本文实例讲述了Android开发之拖动条和评分组件用法。分享给大家供大家参考,具体如下:今天闲着没事做就拿出了Android书接着学习,an
- 当前比较成熟一点的应用基本上都会在进入应用之显示一个启动界面.这个启动界面或简单,或复杂,或简陋,或华丽,用意不同,风格也不同.下面来观摩几
- IBATIS简介ibatis是 Apache的开源项目,一个ORM 解决方案,ibatis最大的特点就是小巧,上手很快。使用 ibatis提
- 在网上翻阅了很多关于ProgressBar滚动效果,但是始终没有找到适合项目中的这种效果,故自己写这篇文章,记录一下写作过程,给大家做一个参