Sqlserver
 sql >> Base de Dados >  >> RDS >> Sqlserver

Por que não consigo encontrar uma chave estrangeira usando a função OBJECT_ID()?


Bem, pode ser que sua chave estrangeira esteja olhando para a tabela não no esquema padrão (provavelmente dbo ). Nesse caso, você não verá object_id até que você especifique o esquema, assim:
SELECT OBJECT_ID(N'<schema>.FK_Name', N'F')

Na verdade, você pode ter vários objetos com o mesmo nome em seu banco de dados, mas em esquemas diferentes. OBJECT_ID(N'FK_Name', N'F') retornará o id do objeto no esquema padrão.

Você pode testar assim:
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

demonstração do violino sql