5、MYSQL-DQL-多表关系

多表查询

一个项目通常需要很多表才能完成。

1. 多表关系

多表之间的关系可以分为:

关系类型 示例场景 实现方式
一对一 一个学生只有一张身份证;一张身份证只能对应一个学生 在任一表中添加唯一外键,指向另一方的主键,以此确保一对一的关联关系
一对多 / 多对一 一个部门有多个员工,一个员工只能对应一个部门 在 "多" 的一方(员工表)建立外键,指向 "一" 的一方(部门表)的主键
多对多 一个学生可选多门课程,一门课程可被多个学生选择 借助第三张中间表实现: 1. 中间表至少包含两个字段; 2. 将多对多拆分为两个一对多关系; 3. 中间表的两个外键分别指向原两张表的主键

1.1 外键约束【foreign key】

1.1.1 添加外键约束(一对多/多对一)

语法格式:

sql 复制代码
方式一:创建表添加外键约束
[contraint <外键名>] foreign key [字段名1,字段名2,...] references <主表名> [主键列1,主键列2,...]

方式二:修改表结构添加外键约束
alter table <表名> add constraint <外键名> foreign key(<列名>) references <主表名>(<列名>)

举例:

sql 复制代码
create database mydb3;
use mydb3;

-- 主表:被其他表的外键引用主键的表(也叫父表);
-- 从表:包含外键、且外键引用其他表主键的表(也叫子表);

-- 创建部门表(主表)
create table if not exists dept (
    deptno varchar(20) primary key, -- 部门号设置主键
    name varchar(20) -- 部门名字
);

--创建员工表(从表)
-- 方式一:创建表添加外键约束
create table if not exists emp (
    eid varchar(20) primary key, -- 员工编号
    ename varchar(20), -- 员工名字
    age int, -- 员工年龄
    dept_id varchar(20), -- 员工所属部门
    constraint emp_fk foreign key(dept_id) references dept(deptno) -- 创建外键
);

--方式二:修改表结构添加外键约束
alter table emp add constraint emp_fk foreign key(dept_id) references dept(deptno);

⚠️:

  • 在添加数据时,必须先给主表添加数据,再添加从表数据。
  • 在删除数据时,如果主表数据被从表依赖,主表的数据不能删除,从表数据可以随意删除。
1.1.2 删除外键约束

语法格式:

sql 复制代码
alter table <表名> drop foreign key <外键约束名>;

举例:

sql 复制代码
alter table emp drop foreign key dept_id_fk;
1.1.3 添加外键约束(多对多)
sql 复制代码
-- 学生表和课程表(多对多)
use mydb3;

-- 1 创建学生表student(左侧主表)
create table if not exists student(
    sid int primary key auto_increment,
    name varchar(20),
    age int,
    gender varchar(20)
);

-- 2 创建课程表course(右侧主表)
create table course(
    cid  int primary key auto_increment,
    cidname varchar(20)
);

-- 3 创建中间表student_course/score(从表)
create table score(
    sid int,
    cid int,
    score double
);

-- 4 建立外键约束(2次)
alter table score add foreign key(sid) references student(sid);
alter table score add foreign key(cid) references course(cid);

-- 5 给学生表添加数据
insert into student values(1,'小龙女',18,'女'),(2,'阿紫',19,'女'),(3,'周芷若',20,'男');

-- 6 给课程表添加数据
insert into course values(1,'语文'),(2,'数学'),(3,'英语');

-- 7 给中间表添加数据
insert into score values(1,1,78),(1,2,75),(2,1,88),(2,3,90),(3,2,80),(3,3,65);
insert into score values(4,1,99); -- 会执行失败,因为 sid=4 的学生在 student 表中不存在,违反了外键约束

⚠️:

  • 在添加数据时,必须先给主表添加数据,再添加从表数据。
  • 在删除数据时,如果主表数据被从表依赖,主表的数据不能删除,从表数据可以随意删除。
相关推荐
一只鹿鹿鹿6 小时前
信息安全等级保护安全建设防护解决方案(总体资料)
运维·开发语言·数据库·面试·职场和发展
堕2746 小时前
MySQL数据库《基础篇--数据库索引(2)》
数据库·mysql
wei_shuo6 小时前
数据库优化器进化论:金仓如何用智能下推把查询时间从秒级打到毫秒级
数据库·kingbase·金仓
71-36 小时前
MySQL的安装和卸载组件
笔记·学习·mysql
雷工笔记6 小时前
Navicat Premium 17 软件安装记录
数据库
wenlonglanying7 小时前
Ubuntu 系统下安装 Nginx
数据库·nginx·ubuntu
数据库小组7 小时前
10 分钟搞定!Docker 一键部署 NineData 社区版
数据库·docker·容器·database·数据库管理工具·ninedata·迁移工具
爬山算法7 小时前
MongoDB(38)如何使用聚合进行投影?
数据库·mongodb
l1t7 小时前
Deep Seek总结的APSW 和 SQLite 的关系
数据库·sqlite
Pocker_Spades_A8 小时前
基于代价模型的连接条件下推:复杂SQL查询的性能优化实践
数据库·sql·性能优化