外键

外键: foreign key,外面的链(键不在自己表中):如果一张表中有一个字段(非主键)指向另外一张表的主键, 那么将该字段称之为外键.

增加外键

外键可以在创建表的时候或者创建表之后增加(但是要考虑数据的问题)。
一张表可以有多个外键。

创建表的时候增加外键:在所有的表字段之后,使用foreign key(外键字段)references 外部表(主键字段)

mysql 外表关联查询 mongodb mysql关联外键_主键

创建失败,原因:无法添加外键约束。

上网搜索,发现需要“确认字段类型,大小是否一致。”以下为表的字段类型(部分)

mysql 外表关联查询 mongodb mysql关联外键_mysql_02


经过修改,最终成功实现。(如下图,由于曾误触关闭,为了得到想要的截图,故重新复制创建代码,由于已经有了外键,故报错)

mysql 外表关联查询 mongodb mysql关联外键_字段_03


查看外键

mysql 外表关联查询 mongodb mysql关联外键_主键_04


在新增表之后增加外键:修改表结构

Alter table表名add [constraint] foreign key(外键字段) references父表(主键字段);

mysql 外表关联查询 mongodb mysql关联外键_字段_05

外键的作用

外键默认的作用有两点: 一个对父表一个对子表(外键字段所在的表)。

对子表約束:子表数据进行写操作的时候。如果对应的外键字段在父表找不到对应的匹配:那么操作会失败(约束子表数据操作)。

mysql 外表关联查询 mongodb mysql关联外键_字段_06


对父表约束:父表数据进行写操作(删和改:都必须涉及到主键本身),如果对应的主键在子表中已经被数据所引用,那么就不允许操作。

mysql 外表关联查询 mongodb mysql关联外键_外键_07

外键条件

1.外键要存在: 首先必须保证表的存储引擎是innodb(默认的存储引擎):如果不是innodb存储引擎,那么外键可以创建成功,但是没有约束效果。

2.外键字段的字段类型(列类型)必须与父表的主键类型完全一致。

3. 一张表中的外键名字不能重复。

4.增加外键的字段(数据已经存在),必须保证数据与父表主键要求对应。

mysql 外表关联查询 mongodb mysql关联外键_主键_08

外键约束

所谓外键约束:就是指外键的作用。
之前所讲的外键作用:是默认的作用;其实可以通过对外键的需求,进行定制操作。

外键约束有三种约束模式:都是针对父表的约束
·Ditric:严格模式(默认的),父表不能删除或者更新一个已经被子表数据引用的记录。
·Cascade:级联模式:父表的操作,对应子表关联的数据也跟着被删除。
·Setnull:置空模式:父表的操作之后子表对应的数据(外键字段)被置空。

通常的一个合理的做法(约束模式):删除的时候子表置空,更新的时候子表级联操作指定模式的语法。

Foreign key(外键字段)references父表(主键字段) on delete set null on update cascade;

mysql 外表关联查询 mongodb mysql关联外键_mysql_09


更新操作:级联更新

mysql 外表关联查询 mongodb mysql关联外键_字段_10


删除操作:置空

mysql 外表关联查询 mongodb mysql关联外键_mysql_11

删除置空的前提条件:外键宇段允许为空(如果不满足条件外键无法创建)

外键虽然很强大,能够进行各种约束:但是对于PHP来讲,外键的约柬降低了PHP对数据的可控性。通常在实际开发中,很少使用外键来处理。

删除外键约束

外键不可以修改,只能先删除后新增。

删除外键语法

Alter table 表名 drop foreign key外键名:

mysql 外表关联查询 mongodb mysql关联外键_mysql_12