这里写自定义目录标题

  • MYSQL如何使用外键
  • 一、增加外键
  • 二、删除外键
  • 三、外键作用
  • 四、外键约束


MYSQL如何使用外键

外键也称之为外键约束: foreign key

外键: 外面的键, 一张表的一个字段(非主键)指向另外一个表的主键, 那么该字段就称之为外键.

外键所在的表称之为子表(附表); 外键所指向的主键所在的表称之为父表(主表)

在MySQL中,InnoDB引擎类型的表支持了外键约束,MyISAM类型暂时不支持外键。

建立外键关系的两个表的列必须是数据类型相似,也就是可以相互转换类型的列,比如int和tinyint可以,而int和char则不可以;此外,联合主键在MYSQL中建立外键会出现一些情况,不建议使用。

外键的好处:可以使得两张表关联,保证数据的一致性和实现一些级联操作。

外键的定义语法:

[CONSTRAINT symbol] FOREIGN KEY [id] (index_col_name, …)
REFERENCES tbl_name (index_col_name, …)
[ON DELETE {RESTRICT | CASCADE | SET NULL | NO ACTION | SET DEFAULT}]
[ON UPDATE {RESTRICT | CASCADE | SET NULL | NO ACTION | SET DEFAULT}]

该语法可以在 CREATE TABLE 和 ALTER TABLE 时使用,如果不指定CONSTRAINT symbol,MYSQL会自动生成一个名字。指定约束名称可以方便维护,删除约束可以用

一、增加外键

将一个表的字段与另外一张表的主键进行关联(实体与实体之间的联系)

增加外键有两种形式

方案1: 在创建表的时候就增加外键: 在表字段之后使用foreign key

foreign key(外键字段) references 主表(主键);

方案2: 在创建表之后增加外键: 指定外键名字

alter table 表名 add constraint 外键名 foreign key(外键字段) references 父表(主键字段)

二、删除外键

外键不能被修改,只能先删除后新增.

alter table 表名 drop foreign key 外键名;

三、外键作用

外键也称之为外键约束: 主要作用在于对数据进行约束.

约束1: 外键对子表的数据写操作约束: (增加和更新): 如果子表中插入的数据所对应的外键在父表不存在: 不能成功.

约束2: 外键对父表也有数据约束: 当父表操作一个记录,但是该记录被子表所引用的时候,那么父表的操作将会被限制(更新主键和删除)

四、外键约束

外键约束: 可以通过在建立外键的时候, 对外键进行约束控制.

约束控制有三种模式

  • 严格模式: district(默认的)
  • 置空模式: set null,对子表的限制: 当父表删除一个被子表引用的记录的时候,会自动的将子表中对应的父表引用(外键)设置成NULL
  • 级联模式: cascade, 级联操作: 当父表对一个被子表引用的数据进行操作的时候,会自动的连带更新子表对应的数据.(更新操作)

模式设定语法: 在外键增加之后(foreign key(外键字段) references 父表(主键)),增加on关键字, 指定操作方式和约束模式. 一个常用的约束模式如下

on update cascade – 级联操作: 父表更新,子表跟着变

on delete set null; – 父表删除, 子表置空