1. 程式人生 > 程式設計 >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,`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,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,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`),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,`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,`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,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專案實戰之線上考試系統的實現(系統介紹),希望對大家有所幫助!