Cannot add foreign key constraint 错误解决办法
产生这个错误的多数原因有一下几点:
-
两张表里要设主键和外键的字段的数据类型或者数据长度不一样 (例如这个是int 另外一个是tinyint,或者都是int,但是设置的长度不同)
-
如果主表中的主键设置了无符号
unsigned
,那么子表中的外键也要设置unsigned
-
某个表里已经有记录了
-
两个表的引擎不一样,查看表的引擎语句:
show table status from 数据库名 where name='表名';
-
要设置外键的字段不能为主键
-
改建所参考的字段必须为主键
-
两个字段必须具有相同的数据类型和约束