以下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实例之间的不同行为。
答案 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;