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、俩张表要建立的主要建字段类型不同。
但是我检查过,没有以上的问题。
我的解决办法就是先把表导出,然后把数据库中的表删除。拿刚刚导出的建表语句重新建表,拿空表和另一张表写添加外键操作。然后就能成功,然后再把数据插入即可,很神奇。