首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >INFORMATION_SCHEMA外键

INFORMATION_SCHEMA外键
EN

Stack Overflow用户
提问于 2012-06-19 12:11:46
回答 1查看 1.7K关注 0票数 1

我有这样的代码,它允许我识别tsql过程中的标识列:

代码语言:javascript
复制
SELECT 
    c.column_name, (columnproperty(object_id(@table_name),c.column_name,'isIdentity')) pk
from information_schema.columns c
where c.table_name = @table_name

有人能帮我修改这段代码,允许识别外键吗?

提前感谢

EN

回答 1

Stack Overflow用户

发布于 2012-06-19 12:14:51

可以使用此table语句获取引用特定表的所有外键:

代码语言:javascript
复制
;WITH ReferencingFK AS 
(
    SELECT 
        fk.Name AS 'FKName',
        OBJECT_NAME(fk.parent_object_id) 'ParentTable',
        cpa.name 'ParentColumnName',
        OBJECT_NAME(fk.referenced_object_id) 'ReferencedTable',
        cref.name 'ReferencedColumnName',
        fk.delete_referential_action,
        fk.update_referential_action
    FROM 
        sys.foreign_keys fk
    INNER JOIN 
        sys.foreign_key_columns fkc ON fkc.constraint_object_id = fk.object_id
    INNER JOIN 
        sys.columns cpa ON fkc.parent_object_id = cpa.object_id AND fkc.parent_column_id = cpa.column_id
    INNER JOIN 
        sys.columns cref ON fkc.referenced_object_id = cref.object_id AND fkc.referenced_column_id = cref.column_id
)
SELECT 
    FKName,
    ParentTable,
    ParentColumnName,
    ReferencedTable,
    ReferencedColumnName
FROM 
    ReferencingFK
WHERE
    ReferencedTable = 'YourTableNameHere'
ORDER BY 
    ParentTable, ReferencedTable, FKName

如果您想要所有外键,那么只需完全删除WHERE子句即可。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/11100637

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档