数据库2表设计
2026/5/7 1:06:27 网站建设 项目流程

1 student

student表的 MySQL 创建语句,包含建表 + 插入示例数据,你可以直接复制到 Navicat 里运行:

sql

-- 1. 创建学生信息表 CREATE TABLE student ( name VARCHAR(50) NOT NULL COMMENT '姓名', code VARCHAR(10) PRIMARY KEY COMMENT '学号' ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='学生信息表'; -- 2. 插入表中的数据 INSERT INTO student (name, code) VALUES ('张三', '001'), ('李四', '002'), ('马五', '003'), ('甲六', '004');

补充说明

  • code设为主键,确保学号唯一且非空,符合业务逻辑。
  • 字符集用utf8mb4,可以兼容所有中文和特殊字符。
  • 表和字段都加了COMMENT注释,方便后续维护。

你直接在 Navicat 的「新建查询」里粘贴这段 SQL,点击运行就能建好表并插入数据了。

2exam

exam表的完整 MySQL 建表语句,包含建表 + 插入数据,和你之前的student表可以完美关联起来:

sql

-- 1. 创建考试信息表 exam CREATE TABLE exam ( code VARCHAR(10) NOT NULL COMMENT '学号', subject VARCHAR(20) NOT NULL COMMENT '学科', score INT NOT NULL COMMENT '成绩', -- 复合主键:学号 + 学科,保证同一个学生同一门课不会有重复记录 PRIMARY KEY (code, subject), -- 外键关联 student 表的学号,保证数据一致性 FOREIGN KEY (code) REFERENCES student(code) ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='考试信息表'; -- 2. 插入表中的数据 INSERT INTO exam (code, subject, score) VALUES ('001', '数学', 80), ('002', '数学', 75), ('001', '语文', 90), ('002', '语文', 80), ('001', '英语', 90), ('002', '英语', 85), ('003', '英语', 80), ('004', '英语', 70);

🔍 关键设计说明

  1. 复合主键PRIMARY KEY (code, subject)保证了「同一个学生同一门学科只能有一条成绩记录」,避免重复数据。
  2. 外键关联FOREIGN KEY (code) REFERENCES student(code)exam表和你之前创建的student表关联起来,保证只有student表里存在的学号才能插入成绩,避免脏数据。
  3. 字段类型
    • scoreINT类型,因为成绩是整数,且范围合理。
    • subjectVARCHAR(20)足够存储常见的学科名称。

✅ 使用步骤

  1. 先确认你之前的student表已经创建并插入了数据(否则外键会报错)。
  2. 把这段 SQL 复制到 Navicat 的查询窗口,点击「运行」即可。
  3. 执行完成后,刷新一下左侧的Test数据库,就能看到exam表了。

需要专业的网站建设服务?

联系我们获取免费的网站建设咨询和方案报价,让我们帮助您实现业务目标

立即咨询