数据库2表设计

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,点击运行就能建好表并插入数据了。

2 exam

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 表了。
相关推荐
怀后同学.2 小时前
SQL注入之堆叠注入和绕过WAF
数据库·sql
重生之小比特2 小时前
【MySQL 数据库】数据类型
数据库·mysql
轻刀快马2 小时前
穿透 MySQL 索引专栏 (二):【核心机制】为什么 SELECT * 是性能杀手?扒开“回表”与“联合索引”的底裤
数据库·mysql
yexuhgu2 小时前
JavaScript中函数防抖Debounce的原理与闭包实现方案
jvm·数据库·python
阿kun要赚马内2 小时前
Python中的ORM——SQLAlchemy
数据库·oracle
m0_613856292 小时前
C#怎么判断进程是否在运行_C#如何管理系统进程【必备】
jvm·数据库·python
NaMM CHIN2 小时前
MySQL无法连接到本地localhost的解决办法2024.11.8
数据库·mysql·adb
Irene19912 小时前
PL/SQL:变量使用 两个连续的外部输入 注意事项
数据库·sql
Jetev2 小时前
golang如何实现审计日志记录_golang审计日志记录实现教程
jvm·数据库·python