微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

sql – 为什么我不能使用OBJECT_ID()函数找到外键?

我在MS sql Server 2012中有一个奇怪的问题.我正在尝试检查升级脚本中是否已存在外键.我过去使用系统OBJECT_ID()函数来查找表,视图和过程,但是当我尝试使用它来查找外键时它不起作用.
-- This query always returns null
SELECT OBJECT_ID(N'FK_Name',N'F')

-- This query works,returning the object ID for the foreign key
SELECT object_id FROM sys.foreign_keys WHERE name=N'FK_Name'

This SO答案表明我的OBJECT_ID()查询应该有效.

解决方法

好吧,可能是你的外键正在寻找不在认架构中的表(可能是dbo).在这种情况下,在指定模式之前,您将看不到object_id,如下所示:
SELECT OBJECT_ID(N'<schema>.FK_Name',N'F')

实际上,您可以在数据库中使用多个具有相同名称的对象,但在不同的模式中. OBJECT_ID(N’FK_Name’,N’F’)将返回认架构中对象的id.

你可以像这样测试它:

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

原文地址:https://www.jb51.cc/mssql/77220.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐