外键:foreign key,外面的键(键不在自己表中):如果A表中有一个字段(非主键)指向B表中的主键,那么称该字段为外键。
外键作用:默认作用有两点:一个对父表,一个对子表(外键字段所在的表)。
对字表约束:字表数据进行写操作(增和改)的时候,如果对应的外键字段在父表找不到对应的匹配,那么操作会失败。(约束字表数据操作)。
对父表约束:父表数据进行写操作(删和改:都必须涉及到主键本身),如果对应的主键在字表中已经被数据所引用,那么就不允许操作。
外键条件:
1.外键要存在首先必须保证表的存储引擎是innodb,如果不是innodb存储引擎,那么即使外键可以创建成功也没有约束效果。
2.外键字段的字段类型(列类型)必须与父表的主键类型完全一致。
3.一张表中外键名字不能重复
4.增加外键的字段(如果数据已经存在),必须保证数据与父表主键对应。
增加外键
外键可以在创建表的时候或者创建表之后增加(但是要考虑数据的问题)。
1.创建表的时候增加外键:在所有的表字段之后,使用foreign key(外键字段)references 外部表(主键字段)。
create table my_foreign1(
id int primary key auto_increment,
name varchar(20) not null comment '学生姓名',
c_id int comment '班级id',
foreign key(c_id) references my_class(id)
)charset utf8;
2.新增表之后增加外键:修改表结构。
Alter table 表名 add[constraint 外键名字] foreign key(外键字段)references 父表(主键字段);
create table my_foreign2(
id int primary key auto_increment,
name varchar(20) not null comment '学生姓名',
c_id int comment '班级id'
)charset utf8;
alter table my_foreign2 add
constraint stu_class_1
foreign key(c_id) references my_class(id);
修改外键&删除外键
外键不可修改:只能先删除后新增。
删除外键:alter table 表名 drop foreign key 外键名;
alter table my_foreign2 drop foreign key stu_class_1;
注意:外键删除的结果不会在表结构中体现出来,可以通过表创建语句来查看是否删除。
外键约束
外键约束就是指外键的作用,这里不是默认的作用
外键约束有三种模式:都是针对父表的约束。
1.district:严格模式(默认的),父表不能删除或更新一个已经被子表数据引用的纪录。
2.cascade:级联模式,父表的操作,对应子表关联的数据也跟着操作。
3.set null:置空模式,父表的操作之后,子表对应的数据(外键字段)被置空。
通常的操作(约束模式):删除的时候子表置空,更新的时候子表级联操作。
指定模式的语法:
foreign key(外键字段) references 父表(主键字段) on delete set null on update cascade;
create table my_foreign3(
id int primary key auto_increment,
name varchar(20) not null comment '学生姓名',
c_id int comment '班级id',
foreign key(c_id) references my_class(id)
on delete set null on update cascade
)charset utf8;
删除置空的前提条件:外键字段允许为空(如果不满足条件,外键无法创建)。