온라인 시험 시스템에서 시험지 생성 및 관리를 지원하기 위해 MySQL 테이블 구조를 어떻게 설계해야 합니까?
온라인 시험 시스템의 시험지 생성 및 관리를 지원하기 위한 MySQL 테이블 구조를 설계하기 전에 먼저 온라인 시험 시스템의 기본 요구 사항과 기능을 이해해야 합니다. 온라인 시험 시스템에는 일반적으로 사용자 관리, 시험지 관리, 문제 관리, 시험 관리 등의 모듈이 포함됩니다. 이번 글에서는 시험지 생성 및 관리의 테이블 구조 설계에 중점을 둘 것입니다.
1. 사용자 관리
사용자 관리 모듈은 사용자 ID, 사용자 이름, 비밀번호, 역할 및 기타 필드를 포함하여 시스템의 사용자 정보를 관리하는 데 사용됩니다. 다음은 간단한 사용자 테이블 예시입니다.
CREATE TABLE `users` ( `id` INT(10) NOT NULL AUTO_INCREMENT, `username` VARCHAR(50) NOT NULL, `password` VARCHAR(50) NOT NULL, `role` ENUM('admin', 'teacher', 'student') NOT NULL, PRIMARY KEY (`id`), UNIQUE KEY `username_UNIQUE` (`username`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;
2. 시험지 관리
시험지 관리 모듈은 시험지 정보를 생성, 수정, 삭제하는 데 사용됩니다. 시험지는 일반적으로 시험지 ID, 시험지 이름, 총점, 작성자 등의 필드를 포함합니다. 다음은 시험지의 간단한 예입니다.
CREATE TABLE `papers` ( `id` INT(10) NOT NULL AUTO_INCREMENT, `name` VARCHAR(100) NOT NULL, `total_score` FLOAT NOT NULL, `creator_id` INT(10) NOT NULL, PRIMARY KEY (`id`), FOREIGN KEY (`creator_id`) REFERENCES `users` (`id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;
3. 문제 관리
문제 관리 모듈은 문제 ID, 문제 유형, 내용, 옵션, 정답, 점수 등의 필드를 포함한 시험 문제 정보를 관리하는 데 사용됩니다. . 다음은 질문지의 간단한 예입니다.
CREATE TABLE `questions` ( `id` INT(10) NOT NULL AUTO_INCREMENT, `paper_id` INT(10) NOT NULL, `type` ENUM('single_choice', 'multiple_choice', 'true_false', 'short_answer') NOT NULL, `content` TEXT NOT NULL, `options` TEXT, `answer` TEXT NOT NULL, `score` FLOAT NOT NULL, PRIMARY KEY (`id`), FOREIGN KEY (`paper_id`) REFERENCES `papers` (`id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;
4. 시험 관리
시험 관리 모듈은 응시자에게 시험지를 할당하고 응시자의 답변과 점수를 기록하는 데 사용됩니다. 다음은 시험표와 답안지의 간단한 예입니다.
CREATE TABLE `exams` ( `id` INT(10) NOT NULL AUTO_INCREMENT, `paper_id` INT(10) NOT NULL, `user_id` INT(10) NOT NULL, `start_time` DATETIME NOT NULL, `end_time` DATETIME, PRIMARY KEY (`id`), FOREIGN KEY (`paper_id`) REFERENCES `papers` (`id`), FOREIGN KEY (`user_id`) REFERENCES `users` (`id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4; CREATE TABLE `answers` ( `id` INT(10) NOT NULL AUTO_INCREMENT, `exam_id` INT(10) NOT NULL, `question_id` INT(10) NOT NULL, `user_id` INT(10) NOT NULL, `answer` TEXT NOT NULL, PRIMARY KEY (`id`), FOREIGN KEY (`exam_id`) REFERENCES `exams` (`id`), FOREIGN KEY (`question_id`) REFERENCES `questions` (`id`), FOREIGN KEY (`user_id`) REFERENCES `users` (`id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;
위 표 구조의 설계를 통해 온라인 시험 시스템의 시험지 생성 및 관리 기능을 구현하고 데이터의 무결성과 일관성을 보장할 수 있습니다. . 실제 응용 프로그램에서는 특정 요구 사항에 따라 보다 복잡한 테이블 구조 설계 및 최적화를 수행할 수 있습니다.
위 내용은 온라인 시험 시스템의 시험지 생성 및 관리를 지원하기 위해 MySQL 테이블 구조를 설계하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!