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

时间:2017-04-24 14:26:23

标签: mysql foreign-keys alter-table

以下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", "1", "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实例之间的不同行为。

1 个答案:

答案 0 :(得分:5)

你可以将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;