1452 - Cannot add or update a child row: a foreign key constraint fails

当遇到MySQL错误1452时,通常是由于外键约束不满足条件导致的。可能的原因包括数据类型不匹配、存储引擎不一致或外键值与参照表中的主键值不匹配。解决方法包括检查并确保数据类型相同,使用InnoDB引擎,并确保外键值与参照表中的值一致。若问题依旧,可以尝试删除外键列并重新创建,或者清空表数据后再创建外键约束。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Mysql错误1452 - Cannot add or update a child row: a foreign key constraint fails

报错主要原因:外键约束出错,意思就是对表进行设置外键时出错。

主要原因分析

原因一:
添加的外键列与另一个表的唯一索引列(一般是主键)的数据类型不同

原因二:
要添加外键的表类型与另一个表的存储引擎是不是都为innodb引擎
#查看表引擎
法一: show create table 表名;
法二:show table status from 数据库 where name=‘表名’;
法三:use information_schema;
select table_catalog,table_schema,table_name,engine from tables
where table_schema=‘数据库名’ and table_name=‘表名’;

原因三:(一般是这个原因)
设置的外键与另一个表中的唯一索引列(一般是主键)中的值不匹配
#解决办法:删除要成为外键的列,再次创建并默认为NULL(或者将有联系的两个表中所有记录行清空,意思就是表中没有数据)
操作之后刷新数据库,然后再重新创建外键约束(本人亲测有效)

参考:
https://blog.csdn.net/weixin_43713105/article/details/89396870

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值