本文重点讲一下如何写出mysql外键约束SQL语句?具体如下:
一、在创建表时设置外键约束
在 CREATE TABLE 语句中,通过 FOREIGN KEY 关键字来指定外键,具体的语法格式如下:
[CONSTRAINT <外键名>] FOREIGN KEY 字段名 [,字段名2,…] REFERENCES <主表名> 主键列1 [,主键列2,…]
1、创建part:
create table part(
nid int not null auto_increment primary key,
caption varchar(32) not null
)
2、创建person:
create table person(
nid int not null auto_increment,
name varchar(32) default null,
email varchar(32) default null,
part_nid int,
primary key(nid),
constraint fk_person_part foreign key (part_nid) references part(nid)
)
创建完之后两张表外键对应的关系:
分析:
1、从名字可以看出SQL语句对应的是什么位置的。
2、图中名(C对应代码中的CONSTRAINT)这行可以不用设,系统会默认帮我设置,但是最好设置,如果要删除外键的时候,就可以通过这个名字进行相应的操作。
二、在修改表时添加外键约束
外键约束也可以在修改表时添加,但是添加外键约束的前提是:从表中外键列中的数据必须与主表中主键列中的数据一致或者是没有数据。
在修改数据表时添加外键约束的语法格式如下:
ALTER TABLE <数据表名> ADD CONSTRAINT <外键名> FOREIGN KEY(<列名>) REFERENCES <主表名> (<列名>);
例如:
alter table person1 add constraint fk_p1_t1 foreign key (part1_nid) references part1(nid);
三、删除外键约束
当一个表中不需要外键约束时,就需要从表中将其删除。外键一旦删除,就会解除主表和从表间的关联关系。
删除外键约束的语法格式如下所示:
ALTER TABLE <表名> DROP FOREIGN KEY <外键约束名>;
例如:
alter table person1 drop foreign key fk_person1_part1;
总结:
如果你想用“Navicat for MySQL”图形界面去操作“mysql添加外键”与“mysql删除外键”的话,请查看: