微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

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

以下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;

原文地址:https://www.jb51.cc/mysql/432883.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐