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

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

  • 2
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值