Sqlserver
 sql >> Base de données >  >> RDS >> Sqlserver

Pourquoi ne puis-je pas trouver une clé étrangère à l'aide de la fonction OBJECT_ID() ?

Eh bien, il se peut que votre clé étrangère regarde la table qui n'est pas dans le schéma par défaut (probablement dbo ). Dans ce cas, vous ne verrez pas object_id jusqu'à ce que vous spécifiiez le schéma, comme ceci :

SELECT OBJECT_ID(N'<schema>.FK_Name', N'F')

En fait, vous pourriez avoir plusieurs objets portant le même nom dans votre base de données, mais dans des schémas différents. OBJECT_ID(N'FK_Name', N'F') renverra l'identifiant de l'objet dans le schéma par défaut.

Vous pouvez le tester comme ceci :

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

démo de violon SQL