Нет, внешний ключ не проверяется.Это довольно легко увидеть, изучив планы выполнения двух разных обновлений.
create table a (
id int primary key
)
create table b (
id int,
fkid int
)
alter table b add foreign key (fkid) references a(id)
insert into a values (1)
insert into a values (2)
insert into b values (5,1) -- Seek on table a's PK
data:image/s3,"s3://crabby-images/007e1/007e1f2415e051f4d631f1b716ad482834cb4372" alt="enter image description here"
update b set id = 6 where id = 5 -- No seek on table a's PK
data:image/s3,"s3://crabby-images/5865a/5865a8ed0861ff265a4defb6da39c1300b1971c8" alt="enter image description here"
update b set fkid = 2 where id = 6 -- Seek on table a's PK
data:image/s3,"s3://crabby-images/803ca/803ca4cbe1b426a7caa0130672b7a9a8c3916d53" alt="enter image description here"
drop table b
drop table a