SQL脚本找到外键到一个特定的表?

前端之家收集整理的这篇文章主要介绍了SQL脚本找到外键到一个特定的表?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
有没有一个查询会让我指向特定表列的外键?例如,说我有这三个表:
  1. __________
  2. |Table A |
  3. ----------
  4. |Id |
  5. ----------
  6.  
  7. ___________
  8. |Table B |
  9. -----------
  10. |Id |
  11. |TableAId | (Foreign Key to TableA.Id)
  12. -----------
  13.  
  14. ___________
  15. |Table C |
  16. -----------
  17. |Id |
  18. |TableAId | (Foreign Key to TableA.Id)
  19. -----------

我需要一个“Select * Foreign Keys directed to TableA.Id”的返回“Table C:TableAId”,“Table B:TableAId”的查询。我正在浏览一些INFORMATION_SCHEMA系统视图,似乎我可以轻松地看到外键属于表A或表B,但我找不到它所在的位置“表C有一个外键表A“具体。我可以弄清楚查询的细节,我找不到我正在寻找的视图(或者我正在掩饰他们)。任何帮助将不胜感激。

解决方法

Courtesy of Pinal Dave:
  1. SELECT
  2. f.name AS ForeignKey,OBJECT_NAME(f.parent_object_id) AS TableName,COL_NAME(fc.parent_object_id,fc.parent_column_id) AS ColumnName,OBJECT_NAME (f.referenced_object_id) AS ReferenceTableName,COL_NAME(fc.referenced_object_id,fc.referenced_column_id) AS ReferenceColumnName
  3. FROM
  4. sys.foreign_keys AS f
  5. INNER JOIN sys.foreign_key_columns AS fc ON f.OBJECT_ID = fc.constraint_object_id

猜你在找的MsSQL相关文章