MySQL 外键约束 多表联查 联合查询

外键约束

外键用来让两张表的数据之间建立连接,从而保证数据的一致性和完整性。

有一张学生表和班级表,学生表通过班级表的ID引用到该班级,从而进行关联,而通过外键约束可以保证数据的一致性完整性。

如学生ID18关联到课程ID1号,发生了关联并且使用了外键,这时删除课程表ID为1的情况下就会失败,因为有关联,这样就保证了数据的完整性。

添加外键

新建表时添加

sql 复制代码
sql
CREATE TABLE orders (
    order_id INT PRIMARY KEY,
    customer_id INT,
    order_date DATE,
    FOREIGN KEY (customer_id) REFERENCES customers(customer_id)
);

已创建的表添加

sql 复制代码
ALTER TABLE 子表名称
ADD CONSTRAINT 外键约束名称
FOREIGN KEY (子表外键字段)
REFERENCES 父表名称(父表关联字段);

实例

sql 复制代码
ALTER  TABLE students ADD CONSTRAINT  students_classes FOREIGN KEY (classes) REFERENCES classes(id)

这时课程表为父表,学生表为子表

效果

创建外键成功后,如果删除班级表,这时有学生关联着会删除失败,

sql 复制代码
DELETE   FROM  classes  WHERE  id=1

翻译过来

删除失败,外键约束

删除外键

sql 复制代码
ALTER TABLE students DROP FOREIGN KEY  外键名称

外键行为

NO ACTION(默认)

当在父表中删除/更新对应记录时,首先检查该记录是否有对应外键,如果有则不允许删除/更新。(与RESTRICT一致)

RESTRICT

当在父表中删除/更新对应记录时,首先检查该记录是否有对应外键,如果有则不允许删除/更新。(与NOACTION 致)

这两个是一样的

CASCADE

当在父表中删除/更新对应记录时,首先检查该记录是否有对应外键,如果有则也删除/更新外键在子表中的记录。也就是说会删除子表关联的数据

SET NULL

当在父表中删除对应记录时,首先检查该记录是否有对应外键,如果有则设置子表中该外键值为nul(这就要求该外键允许取nul)。删除父表的数据时候子表关联的数据会设置成null

SET DEFAULT

父表有变更时,子表将外键列设置成一个默认的值(Innodb不支持)

相关推荐
在坚持一下我可没意见7 小时前
Python 修仙修炼录 05:循环神通,省去无用苦修
开发语言·python·面试·入门·循环·复习
Java成神之路-7 小时前
解密 MySQL 索引性能:为什么主键必须有序?
mysql
北风朝向7 小时前
Spring Boot 集成 Open WebUI 实现 AI 流式对话
人工智能·spring boot·状态模式
未若君雅裁7 小时前
MySQL索引原理-InnoDB-B+树结构与查询过程
b树·mysql
还没学会摸鱼的钓鱼仔7 小时前
手撕 LangChain Deep Agents 源码 (一):create_deep_agent 是如何"组装"出一个 AI 操作系统的
后端
2501_921939267 小时前
Redis
数据库·redis·缓存
用户298698530147 小时前
Java 操作 Word 文档:数学公式与符号的插入方法
java·后端
techdashen7 小时前
Rust 社区在 4 月做了什么:项目管理月报解读
开发语言·rust·mfc
小撒的私房菜7 小时前
Day 5:Agent Loop——整个系列里最关键的一天
人工智能·后端
十五年专注C++开发7 小时前
QFluentKit: 一个基于 Qt Widgets 的 Fluent Design 风格 UI 组件库
开发语言·c++·qt·ui·qfluentkit