Sqlserver
 sql >> Datenbank >  >> RDS >> Sqlserver

Warum kann ich mit der Funktion OBJECT_ID() keinen Fremdschlüssel finden?

Nun, es könnte sein, dass Ihr Fremdschlüssel nach der Tabelle sucht, die sich nicht im Standardschema befindet (wahrscheinlich dbo ). In diesem Fall sehen Sie object_id nicht bis Sie das Schema wie folgt angeben:

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

Tatsächlich könnten Sie mehrere Objekte mit demselben Namen in Ihrer Datenbank haben, aber in unterschiedlichen Schemas. OBJECT_ID(N'FK_Name', N'F') gibt die ID des Objekts im Standardschema zurück.

Sie können es wie folgt testen:

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

SQL-Fiddle-Demo