数据库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 表了。
相关推荐
倔强的石头_9 小时前
《Kingbase护城河》——数据库存储空间全景探测与精细化瘦身实战
数据库
冬奇Lab1 天前
每日一个开源项目(第134篇):Zvec - 阿里开源的嵌入式向量数据库,向量搜索界的 SQLite
数据库·人工智能·llm
ClouGence1 天前
Oracle CDC 架构优化:从主库直连到 DataGuard 备库同步
数据库·后端·oracle
无响应de神1 天前
三、用户与权限管理
数据库·mysql
麦聪聊数据2 天前
数据服务化时代:企业数据能力输出的核心路径
数据库
shushangyun_2 天前
2026年快消品B2B系统推荐:支持终端门店订货、促销政策自动化的工具?
java·运维·网络·数据库·人工智能·spring·自动化
DARLING Zero two♡2 天前
【MySQL数据库】数据类型与表约束
数据库·mysql
曹牧2 天前
Oracle EXPLAIN PLAN
数据库·oracle
BD_Marathon2 天前
SQL学习指南——视图
数据库·sql
活宝小娜2 天前
mysql详细安装教程
数据库·mysql·adb