MySQL 5.7.18:外键约束和ALTER TABLE CHANGE COLUMN从NULL到NOT NULL

MySQL 5.7.18:外键约束和ALTER TABLE CHANGE COLUMN从NULL到NOT NULL,第1张

概述以下SQL脚本适用于MySQL 5.16.17及更早版本,但不适用于我的MySQL 5.7.18安装之一(另一个,在Docker容器中启动的MySQL 5.7.18也可以)drop table if exists bar; drop table if exists foo; create table foo (foo_id int not null pri

以下sql脚本适用于MySQL 5.16.17及更早版本,但不适用于我的MysqL 5.7.18安装之一(另一个,在Docker容器中启动的MysqL 5.7.18也可以)

drop table if exists bar;drop table if exists foo;create table foo (foo_ID int not null primary key,description varchar(32));insert into foo values ("1","foo-one");insert into foo values ("2","foo-two");create table bar (bar_ID int not null primary key,foo_ID int null,description varchar(32),foreign key (foo_ID) references foo(foo_ID));insert into bar values ("1","1","bar-one");insert into bar values ("2","bar-two");alter table bar change column foo_ID foo_ID int not null;

错误消息是:

Error Code: 1832. Cannot change column 'foo_ID': used in a foreign key constraint 'bar_ibfk_1'

问题似乎是将外键约束从NulL更改为NOT NulL.

我知道我可以将最后一个语句包装在“SET foreign_key_checks …”调用中,但我感兴趣的是在这种情况下是否有任何系统变量或配置设置会影响MysqL的行为,因为我无法解释两个5.7.18实例之间的不同行为.

最佳答案您可以将FOREIGN_KEY_CHECKS设置为零

SET FOREIGN_KEY_CHECKS = 0;alter table bar change column foo_ID foo_ID int not null;SET FOREIGN_KEY_CHECKS = 1;
总结

以上是内存溢出为你收集整理的MySQL 5.7.18:外键约束和ALTER TABLE CHANGE COLUMN从NULL到NOT NULL全部内容,希望文章能够帮你解决MySQL 5.7.18:外键约束和ALTER TABLE CHANGE COLUMN从NULL到NOT NULL所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/1168695.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-01
下一篇 2022-06-01

发表评论

登录后才能评论

评论列表(0条)

保存