mysql启动和关闭外键约束的方法(FOREIGN_KEY_CHECKS)

在MySQL中删除一张表或一条数据的时候,出现

[Err] 1451 -Cannot delete or update a parent row: a foreign key constraint fails (...)

这是因为MySQL中设置了foreign key关联,造成无法更新或删除数据。可以通过设置FOREIGN_KEY_CHECKS变量来避免这种情况。

我们可以使用

    SET FOREIGN_KEY_CHECKS=0;
来禁用外键约束.
 
之后再用
    SET FOREIGN_KEY_CHECKS=1;
来启动外键约束.
 
查看当前FOREIGN_KEY_CHECKS的值可用如下命令

    SELECT  @@FOREIGN_KEY_CHECKS;

我先设置禁用外键约束,但是后面插入的时候发现还是报错。

我觉得原因是一开始删表改表更改了数据库,导致又有了外键约束。

我就在每条Insert into前面都加了SET FOREIGN_KEY_CHECKS=0;  

后面就可以了

猜你喜欢

转载自blog.csdn.net/xuhaogang3/article/details/81099003