MySQL错误代码:1452 Cannot add or update a child row: a foreign key constraint fails

1
2
3
4
5
6
查询:ALTER TABLE score ADD FOREIGN KEY(movie_id) REFERENCES `movie` (id) 错误代码: 1452
Cannot add or update a child row: a foreign key constraint fails (`mydb`.`#sql-1118_1`, CONSTRAINT `#sql-1118_1_ibfk_2` FOREIGN KEY (`movie_id`) REFERENCES `movie` (`id`))

执行耗时   : 0 sec
传送时间   : 0 sec
总耗时      : 0.046 sec

这个错误是我在给已创建的表添加外键的时候报的错误,表以及创建好了,数据也有,其他表都可以创建外键关系,但是唯独有俩张表,无论怎么样写都会报上面的错误。

网上找了半天解决办法,大部分都是

1、俩张表的存储引擎不同,要都改为innoDB。

2、俩张表要建立的主要建字段类型不同。

但是我检查过,没有以上的问题。

我的解决办法就是先把表导出,然后把数据库中的表删除。拿刚刚导出的建表语句重新建表,拿空表和另一张表写添加外键操作。然后就能成功,然后再把数据插入即可,很神奇。