[Err] 1701 - Cannot truncate a table referenced in a foreign key constraint

在清空表中数据时报错:
[SQL]truncate table ACT_RE_DEPLOYMENT ;
[Err] 1701 - Cannot truncate a table referenced in a foreign key constraint (`act`.`ACT_GE_BYTEARRAY`, CONSTRAINT `ACT_FK_BYTEARR_DEPL` FOREIGN KEY (`DEPLOYMENT_ID_`) REFERENCES `act`.`ACT_RE_DEPLOYMENT` (`ID_`))
报错的意思大概是:不能清空具有外键约束的表*,然后有常识了delete语句,添加了伪条件where 1=1,记得之前有这样的情况然后还是报错,

原因清空具有外键约束的表就会报错

[SQL]
DELETE FROM ACT_RE_DEPLOYMENT where 1=1;
[Err] 1451 - Cannot delete or update a parent row: a foreign key constraint fails (`act`.`ACT_GE_BYTEARRAY`, CONSTRAINT `ACT_FK_BYTEARR_DEPL` FOREIGN KEY (`DEPLOYMENT_ID_`) REFERENCES `ACT_RE_DEPLOYMENT` (`ID_`))

解决方法是:

1.SET FOREIGN_KEY_CHECKS=0;

2.DELETE FROM ACT_RE_DEPLOYMENT where 1=1;
-- 或
-- truncate table ACT_RE_DEPLOYMENT ;

3.SET FOREIGN_KEY_CHECKS=1;

Mysql中如果表和表之间建立的外键约束,则无法删除表及修改表结构。

解决方法是:

1、首先取消外键约束:SET FOREIGN_KEY_CHECKS=0;

2、修改表数据或表结构

3、然后再设置外键约束: SET FOREIGN_KEY_CHECKS=1;




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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值