1. ホーム
  2. .net

[解決済み] SQL Serverで外部キーの依存性を見つけるには?

2022-04-23 12:41:15

質問

特定のカラムに対する外部キーの依存関係をすべて見つけるにはどうすればよいですか?

別の選択肢(SSMS のグラフィカルな表示、SQL Server のクエリー/ビュー、サードパーティのデータベースツール、.NET のコード)にはどのようなものがありますか?

解決方法は?

次のクエリが参考になります。これは、現在のデータベース内のすべての外部キー・リレーションシップを一覧表示します。

SELECT
    FK_Table = FK.TABLE_NAME,
    FK_Column = CU.COLUMN_NAME,
    PK_Table = PK.TABLE_NAME,
    PK_Column = PT.COLUMN_NAME,
    Constraint_Name = C.CONSTRAINT_NAME
FROM
    INFORMATION_SCHEMA.REFERENTIAL_CONSTRAINTS C
INNER JOIN INFORMATION_SCHEMA.TABLE_CONSTRAINTS FK
    ON C.CONSTRAINT_NAME = FK.CONSTRAINT_NAME
INNER JOIN INFORMATION_SCHEMA.TABLE_CONSTRAINTS PK
    ON C.UNIQUE_CONSTRAINT_NAME = PK.CONSTRAINT_NAME
INNER JOIN INFORMATION_SCHEMA.KEY_COLUMN_USAGE CU
    ON C.CONSTRAINT_NAME = CU.CONSTRAINT_NAME
INNER JOIN (
            SELECT
                i1.TABLE_NAME,
                i2.COLUMN_NAME
            FROM
                INFORMATION_SCHEMA.TABLE_CONSTRAINTS i1
            INNER JOIN INFORMATION_SCHEMA.KEY_COLUMN_USAGE i2
                ON i1.CONSTRAINT_NAME = i2.CONSTRAINT_NAME
            WHERE
                i1.CONSTRAINT_TYPE = 'PRIMARY KEY'
           ) PT
    ON PT.TABLE_NAME = PK.TABLE_NAME

また、SQL Server Management Studio の Database Diagrams で、リレーションシップをグラフィカルに表示することもできます。