ホームページ > データベース > mysql チュートリアル > SQL Server の information_schema を使用して外部キー参照を検索する方法

SQL Server の information_schema を使用して外部キー参照を検索する方法

Linda Hamilton
リリース: 2025-01-02 19:17:39
オリジナル
342 人が閲覧しました

How to Find Foreign Key References Using SQL Server's information_schema?

SQL Server の information_schema から外部キー参照を取得する

質問:

SQL Server の場合、外部テーブルに関連付けられた参照テーブルと列の名前を確認するにはどうすればよいですか? key?

答え:

information_schema は、外部キー関係を含む、データベース オブジェクトに関する貴重なメタデータを提供します。参照されるテーブルと列の情報を取得するには、次のクエリを使用できます:

SELECT 
     KCU1.CONSTRAINT_SCHEMA AS FK_CONSTRAINT_SCHEMA 
    ,KCU1.CONSTRAINT_NAME AS FK_CONSTRAINT_NAME 
    ,KCU1.TABLE_SCHEMA AS FK_TABLE_SCHEMA 
    ,KCU1.TABLE_NAME AS FK_TABLE_NAME 
    ,KCU1.COLUMN_NAME AS FK_COLUMN_NAME 
    ,KCU1.ORDINAL_POSITION AS FK_ORDINAL_POSITION 
    ,KCU2.CONSTRAINT_SCHEMA AS REFERENCED_CONSTRAINT_SCHEMA 
    ,KCU2.CONSTRAINT_NAME AS REFERENCED_CONSTRAINT_NAME 
    ,KCU2.TABLE_SCHEMA AS REFERENCED_TABLE_SCHEMA 
    ,KCU2.TABLE_NAME AS REFERENCED_TABLE_NAME 
    ,KCU2.COLUMN_NAME AS REFERENCED_COLUMN_NAME 
    ,KCU2.ORDINAL_POSITION AS REFERENCED_ORDINAL_POSITION 
FROM INFORMATION_SCHEMA.REFERENTIAL_CONSTRAINTS AS RC 

INNER JOIN INFORMATION_SCHEMA.KEY_COLUMN_USAGE AS KCU1 
    ON KCU1.CONSTRAINT_CATALOG = RC.CONSTRAINT_CATALOG  
    AND KCU1.CONSTRAINT_SCHEMA = RC.CONSTRAINT_SCHEMA 
    AND KCU1.CONSTRAINT_NAME = RC.CONSTRAINT_NAME 

INNER JOIN INFORMATION_SCHEMA.KEY_COLUMN_USAGE AS KCU2 
    ON KCU2.CONSTRAINT_CATALOG = RC.UNIQUE_CONSTRAINT_CATALOG  
    AND KCU2.CONSTRAINT_SCHEMA = RC.UNIQUE_CONSTRAINT_SCHEMA 
    AND KCU2.CONSTRAINT_NAME = RC.UNIQUE_CONSTRAINT_NAME 
    AND KCU2.ORDINAL_POSITION = KCU1.ORDINAL_POSITION 
ログイン後にコピー

追加の考慮事項:

  • 一意の制約: Information_schema はインデックスを追跡せず、一意の制約のみを追跡します。一意のインデックスに基づいて外部キーを見つけるには、sys.foreign_keys や sys.key_constraints などの Microsoft 独自のテーブルをクエリできます。
  • 証明テスト: 提供されているエッジケース テストは、正しい方法を示しています。外部キー制約や一意性制約を含むさまざまなシナリオで参照されるテーブルと列の情報を識別するインデックス。

以上がSQL Server の information_schema を使用して外部キー参照を検索する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート