如果在最初建立表的时候就建立外键这样一般不会有什么问题,顺便说一下建立外键的时候,需要注意的地方。
cascade方式
在父表上update/delete记录时,同步update/delete掉子表的匹配记录
set null方式
在父表上update/delete记录时,将子表上匹配记录的列设为null
要注意子表的外键列不能为not null
No action方式
如果子表中有匹配的记录,则不允许对父表对应候选键进行update/delete操作
Restrict方式
同no action, 都是立即检查外键约束
Set default方式
父表有变更时,子表将外键列设置成一个默认的值 但Innodb不能识别。
建立外键的命令:
alter table current_table_name add foreign key fk_name(stockid) references table_name(stockid)
current_table_name 为表名, fk_name 为外键名 第一个括号里填写外键列名, table_name为被引用的表的名子,第二个括号里是写被外键关联的列名
当表中有一定的数据的时候,这个时候如果要建立外键(foreign key)要注意数据的一致性,否则会出现错误。
尽量不要使用:
SET FOREIGN_KEY_CHECKS = 0;
关闭了外键约束,此时外键也就失去了意义,可能会导致数据不一致的问题出现,出现僵尸数据。