如何在一个表中的不同字段之间获取FK?

时间:2017-03-03 11:38:44

标签: sql-server

如何从DB中获取所有约束,其中一个字段被引用到同一个表中的另一个字段?

这种类型的引用会强烈影响性能,所以我想在我的数据库中找到所有这些引用并进行分析。

表结构示例:

CREATE TABLE MyTable(id uniqueidentifier NOT NULL PRIMARY KEY, ReferentID uniqueidentifier)

ALTER TABLE [dbo].MyTable  WITH CHECK ADD  CONSTRAINT [TEST_FK] FOREIGN KEY([ReferentID])
REFERENCES [dbo].MyTable ([Id])
GO

ALTER TABLE [dbo].MyTable CHECK CONSTRAINT [TEST_FK]
GO

2 个答案:

答案 0 :(得分:1)

您可以从此foreign keys

获取所有procedure
EXEC sp_fkeys 'MyTable';

或您可以使用:

select * from sysobjects where xtype='F';

答案 1 :(得分:1)

this答案中的查询开始,您可以添加过滤器以仅获取引用同一表的FK。

生成的查询应如下所示:

$(function(){
    $(document.body).on('click tap touchstart', 'h1', function(){
        console.log("Test 2");
    })
})