Może być tak, że twój klucz obcy szuka tabeli nie w domyślnym schemacie (prawdopodobnie dbo
). W takim przypadku nie zobaczysz object_id
dopóki nie określisz schematu, w ten sposób:
SELECT OBJECT_ID(N'<schema>.FK_Name', N'F')
W rzeczywistości możesz mieć wiele obiektów o tej samej nazwie w swojej bazie danych, ale w różnych schematach. OBJECT_ID(N'FK_Name', N'F')
zwróci id obiektu w domyślnym schemacie.
Możesz to przetestować w ten sposób:
create schema test
create table test.temp1 (id int primary key)
create table test.temp2 (id int)
go
alter table test.temp2 add constraint FK_temp foreign key(id) references test.temp1(id)
select object_id('FK_temp', 'F') -- returns null
select object_id('test.FK_temp', 'F') -- returns object id
drop table test.temp2
drop table test.temp1
drop schema test