1、在CREATE TABLE语句中,通过FOREIGN KEY关键字来添加外键;

2、在ALTER TABLE语句中,通过ADD和FOREIGN KEY关键字来添加外键。
外键的设计初衷是为了在数据库端保证对逻辑上相关联的表数据在操作上的一致性与完整性。
精简关联数据,减少数据冗余避免后期对大量冗余处理的额外运维操作。
降低应用代码复杂性,减少了额外的异常处理相关数据管理全由数据库端处理。
增加文档的可读性特别是在表设计开始,绘制 ER 图的时候,逻辑简单明了,可读性非常强。
性能压力外键一般会存在级联功能,级联更新,级联删除等等。在海量数据场景,造成很大的性能压力。比如插入一条新记录,如果插入记录的表有 10 个外键,那势必要对关联的 10 张表逐一检查插入的记录是否合理,延误了正常插入的记录时间。并且父表的更新会连带子表加上相关的锁。
其他功能的灵活性不佳比如,表结构的更新等。
外键参照动作列表:
CASCADE:级联,子表跟随父表更新外键值
SET NULL:子表更随主表更新外键值为 NULL
RESTRICT/ NO ACTION:默认,限制父表改动外键值
SET DEFAULT:目前产生的效果和 RESTRICT 相同。
在MySQL中,您可以使用以下步骤设置主键和外键:
- 设置主键:在创建表时,可以使用PRIMARY KEY约束来定义主键。主键是一个或多个字段,它的值用于唯一地标识表中的某一条记录 。
- 设置外键:在创建表时,可以使用FOREIGN KEY约束来定义外键。外键是用于建立或加强两个表数据之间的链接的一列或多列。如果公共关键字在一个表中存在,而在另一个表中不存在,则必须使用FOREIGN KEY约束来定义外键 。
外键的作用:外键主要用来保证数据的完整性和一致性,便于关系数据的日常维护。是两张关系表中的主表数据修改或删除是自动操作字表中的数据。(外键并不是费用不可,通过程序逻辑上的操作完全可以替代)
1、两个表必须是InnoDB表,MyISAM表暂时不支持外键
2、如果在较早的版本(4.1.2以前)则需要显示建立外键列必须建立了索引
3、外键关系的两个表的列必须是数据类型相似。比如int和tinyint可以,而int和char则不可以
外键约束使用最多的两种情况:
1)父表更新时子表也更新,父表删除时如果子表有匹配的项,删除失败;
2)父表更新时子表也更新,父表删除时子表匹配的项也删除。
前一种情况,在外键定义中,用ON UPDATE CASCADE ON DELETE RESTRICT;
后一种情况,可以使用ON UPDATE CASCADE ON DELETE CASCADE。
举例说明:用最常见的场景:文章表,和分类表;
现在删除分类表中的一条数据:
文章表添加一条数据:
这样是不是就保证了文章表里的分类ID 都能在分类表找到对应的名称啦?
下面我们删除外键重新创建: