三十四、外键约束

简介: 三十四、外键约束

一、参照完整性

参照完整性要求关系中不允许引用不存在的实体。在 MySQL 中设置参照完整性的方式是使用 外键约束 。所谓外键就是用于在两个表中的数据之间建立和加强链接的一列或多列的组合,可控制可在外键表中存储的数据。例如,有学生表和分数表两个表,表内容如下。


student 学生表:

image.png

score 分数表:

image.png在分数表中有 stu_no 列存储的是学生表中的学生编号,当我们把这个字段设置为分数表的外键字段后,插入一条不存在的学生的分数将会报错。例如插入一条stu_no 编号为 2021003 的学生的分数,这时 MySQL 将会报错。这是因为在学生表中不存在编号为 2021003 的学生,如果想插入成功则必须现在学生表中创建编号为 2021003 这个学生后再向分数表插入这个学生的分数。


二、外键约束

上一小节提到了外键约束,那么什么是外键约束呢?外键约束是用于保持主表(父表)和从表(子表)的数据一直。在 MySQL 中只有 InnoDB 存储引擎支持外键约束。外键约束的语法如下:

[CONSTRAINT [symbol]] FOREIGRN KEY [index_name] (col_name,...) REFERENCES tbl_name(col_name,...)
[ON DELETE reference_option]
[ON UPDATE reference_option]

在语法中 reference_option 指的是外键约束条件,外键约束条件包括如下五种选项:


  1. RESTRICT:拒绝对父表的删除或更新操作;
  2. CASCADE:从父表删除或更新时自动删除或更新子表中匹配的行;
  3. SET NULL:从父表删除或更新时自动设置子表对应的外键列为NULL;
  4. NO ACTION: 不采取任何动作;
  5. SET DEFAULT:使用默认约束


例子:

前述的学生表的分数表可以这样创建:

# 创建学生表
create table student(
    stu_no varchar(30) not null primary key,
    name varchar(30),
    phone varchar(30)
) engine=InnoDB
# 创建分数表,设置 stu_no 为外键
create table score(
    score_no int not null auto_increment primary key,
    stu_no varchar(30),
    gross_score int,
    foreign key(stu_no) references student(stu_no)
) engine=InnoDB
目录
相关文章
|
3月前
|
iOS开发 开发者 UED
利用SwiftUI构建动态列表:iOS开发的新范式
【4月更文挑战第22天】在本文中,我们将深入探讨如何使用SwiftUI来创建动态列表。SwiftUI是苹果最新推出的用户界面工具集,它允许开发者以声明式的方式描述用户界面,从而简化了代码的复杂性。我们将通过具体的代码实例,展示如何利用SwiftUI的List和ForEach视图来创建动态列表,并讨论其在实际开发中的应用。
52 2
|
数据库
设计外键的界面
设计外键的界面
38 0
|
9月前
|
数据建模 Java 数据库
PowerDesigner使用之为表中字段添加索引
PowerDesigner使用之为表中字段添加索引
281 1
|
10月前
|
存储 SQL 关系型数据库
MySQL基础下篇[表的创建/约束的使用/事务和范式以及索引的使用]~2
MySQL基础下篇[表的创建/约束的使用/事务和范式以及索引的使用]~2
|
10月前
|
SQL 存储 关系型数据库
MySQL基础下篇[表的创建/约束的使用/事务和范式以及索引的使用]~3
MySQL基础下篇[表的创建/约束的使用/事务和范式以及索引的使用]~
|
10月前
|
SQL 存储 关系型数据库
MySQL基础下篇[表的创建/约束的使用/事务和范式以及索引的使用]~1
MySQL基础下篇[表的创建/约束的使用/事务和范式以及索引的使用]~
|
存储 关系型数据库 MySQL
开发规范中为什么要禁用外键约束
开发规范中为什么要禁用外键约束
1396 0
开发规范中为什么要禁用外键约束
|
存储 关系型数据库 MySQL
MySQL数据库约束与表的设计
本文主要介绍MySQL数据库中一些常用的约束,以及表的设计方法。
123 0
MySQL数据库约束与表的设计
|
关系型数据库 MySQL 数据库
|
存储 SQL 关系型数据库
MySQL基础-约束
上面我们介绍了数据库中常见的约束,以及约束涉及到的关键字,那这些约束我们到底如何在创建表-修改表的时候来指定呢,接下来我们就通过一个案例,来演示一下。
94 0