答案:设计问卷调查系统数据库需明确功能并建立核心表结构。首先确定系统支持创建问卷、设计问题、填写答卷及统计分析,对应数据实体为问卷、问题、选项、答卷和回答。使用mysql的InnoDB引擎,创建五张表:surveys表存储问卷信息;questions表关联问卷与问题,并用question_type区分题型;options表为选择题提供选项;responses表记录每次提交;answers表存储具体回答,通过option_id和answer_text兼容不同题型。外键约束保障数据完整性,便于级联删除与结果统计。该结构灵活可扩展,新增题型只需修改枚举值,基础架构稳定清晰,适合大多数问卷场景。

搭建一个问卷调查系统的数据库,核心是设计清晰、灵活且可扩展的数据结构。MySQL 作为常用的关系型数据库,非常适合这类应用。以下是构建问卷调查系统数据库的关键步骤和表结构设计建议。
1. 明确系统核心功能
在建表前,先理清系统需要支持的功能:
- 创建问卷(标题、描述、发布时间)
- 设计问题(单选、多选、填空等题型)
- 用户填写问卷并提交答案
- 统计分析结果
基于这些功能,可以拆解出主要数据实体:问卷、问题、选项、答卷、回答。
2. 设计数据库表结构
以下是推荐的表结构设计,使用 InnoDB 引擎以支持外键和事务。
(1)问卷表(surveys)
存储问卷基本信息。
CREATE TABLE surveys ( id INT AUTO_INCREMENT PRIMARY KEY, title VARCHAR(255) NOT NULL, description TEXT, created_at DATETIME DEFAULT CURRENT_TIMESTAMP, is_active TINYINT(1) DEFAULT 1 COMMENT '是否启用' );
(2)问题表(questions)
每个问题属于一个问卷,支持不同题型。
CREATE TABLE questions ( id INT AUTO_INCREMENT PRIMARY KEY, survey_id INT NOT NULL, question_text TEXT NOT NULL, question_type ENUM('radio', 'checkbox', 'text') NOT NULL COMMENT '题型', sort_order INT DEFAULT 0 COMMENT '排序', FOREIGN KEY (survey_id) REFERENCES surveys(id) ON DELETE CAScadE );
(3)选项表(options)
为选择类问题(单选/多选)提供选项。
CREATE TABLE options ( id INT AUTO_INCREMENT PRIMARY KEY, question_id INT NOT NULL, option_text VARCHAR(255) NOT NULL, sort_order INT DEFAULT 0, FOREIGN KEY (question_id) REFERENCES questions(id) ON DELETE CASCADE );
(4)答卷表(responses)
记录每次用户提交的问卷实例。
CREATE TABLE responses ( id INT AUTO_INCREMENT PRIMARY KEY, survey_id INT NOT NULL, submitted_at DATETIME DEFAULT CURRENT_TIMESTAMP, FOREIGN KEY (survey_id) REFERENCES surveys(id) );
(5)回答表(answers)
存储用户对每个问题的具体回答。
CREATE TABLE answers ( id INT AUTO_INCREMENT PRIMARY KEY, response_id INT NOT NULL, question_id INT NOT NULL, option_id INT DEFAULT NULL COMMENT '选择类答案对应选项', answer_text TEXT COMMENT '填空类答案文本', FOREIGN KEY (response_id) REFERENCES responses(id) ON DELETE CASCADE, FOREIGN KEY (question_id) REFERENCES questions(id), FOREIGN KEY (option_id) REFERENCES options(id) );
3. 关键设计说明
这种设计的优势在于:
- 灵活性:通过 question_type 区分题型,option_id 和 answer_text 分开存储,兼容多种回答方式
- 可扩展性:新增题型只需扩展枚举值,不影响现有结构
- 数据完整性:外键约束确保问卷删除时相关数据自动清理
- 便于统计:通过 response_id 聚合一次完整填写,方便分析
4. 常用查询示例
获取某问卷的所有回答数据:
SELECT s.title, q.question_text, o.option_text, a.answer_text FROM responses r JOIN answers a ON r.id = a.response_id JOIN questions q ON a.question_id = q.id JOIN surveys s ON q.survey_id = s.id LEFT JOIN options o ON a.option_id = o.id WHERE s.id = 1;
统计某个单选题各选项被选次数:
SELECT o.option_text, COUNT(a.id) as count FROM answers a JOIN options o ON a.option_id = o.id WHERE a.question_id = 10 GROUP BY o.id;
基本上就这些。这套结构能支撑大多数问卷场景,后续可根据需求添加用户表、逻辑跳转、附件上传等功能。关键是保持基础结构清晰,避免过度复杂化。


