MySQL的外键约束FOREIGN KEY

版权声明:本文原创,转载请注明出处。 https://blog.csdn.net/weixin_39004901/article/details/89088813

一、建立外键约束
语法如下:

[CONSTRAINT [symbol]] FOREIGN KEY
 [index_name] (col_name, ...)
 REFERENCES tbl_name (col_name,...)
 [ON DELETE reference_option]
 [ON UPDATE reference_option]
reference_option:
 RESTRICT | CASCADE | SET NULL | NO ACTION | SET DEFAULT

1.CONSTRAINT [symbol]]指定约束名字,不写则系统自动生成外键约束名;
2.MySQL强制外键约束的列上必须要有索引, [index_name]指定索引名,不写则系统自动生成索引名,如果已经存在可以用于支持外键约束的索引,那么指定的索引名则无效,采用已有的索引;
3. [ON DELETE reference_option][ON UPDATE reference_option]指定主表update和delete操作时,子表对应的数据怎么响应;

建立外键约束例子如:

create table tab1 (id int primary key);
create table tab2 (
id int primary key,
col1 int,
foreign key (col1)
references tab1(id)
);

下面看一下[ON DELETE reference_option][ON UPDATE reference_option]reference_option都有哪些参数:
1.CASCADE,级联删除/级联更新,即主表delete或update了被其他表引用的数据,对应子表的数据也被delte或update;
2.SET NULL,当主表delete或update了被其他表引用的数据,对应子表的数据被设为null,注意子表的外键不能设为not null;
3.RESTRICT,主表不允许delete或update被其他表引用的数据;当没有指定任何[ON DELETE reference_option][ON UPDATE reference_option],默认是采用RESTRICT;
4.NO ACTION,在MySQL中,等效于RESTRICT;
5.SET DEFAULT,InnoDB和NDB中无法使用才参数。

二、添加外键约束
语法如下:

ALTER TABLE tbl_name
 ADD [CONSTRAINT [symbol]] FOREIGN KEY
 [index_name] (col_name, ...)
 REFERENCES tbl_name (col_name,...)
 [ON DELETE reference_option]
 [ON UPDATE reference_option]

基本的语法参数在上文已经解释了。

三、删除外键约束
语法如下:

ALTER TABLE tbl_name DROP FOREIGN KEY fk_symbol;

fk_symbol即外键约束名,如果不知道具体是什么,可以使用show create table tab_name\G来查看。

四、外键约束注意事项
1.外键上无法插入主表没有的数据,也无法更新为主表没有的数据;
2.外键上必须要有索引,主表上对应的列最好也创建索引,因为当子表外键插入数据时,也是需要到主表对应的列上去检查数据是否存在,有索引可以提高效率;
3.如果一个表被其他表的外键引用,则这个表无法被删除;如果通过set foreign_key_checks=0强制删除主表,则子表无法插入任何数据;
4.外键的字段类型,字符集必须要跟引用的字段一致,unsigned也要一直,否则无法创建外键约束;
5.被引用的列上必须要有索引,否则无法创建外键约束。

猜你喜欢

转载自blog.csdn.net/weixin_39004901/article/details/89088813
今日推荐