外部キーを使用して非主キー列の参照整合性を維持します
データベース システムでは、外部キーを使用してテーブル間の関係を確立し、参照整合性を強制します。通常、外部キーは他のテーブルの主キーを参照して、依存テーブル内のデータの一貫性を確保します。ただし、場合によっては、主キー以外の列を指す外部キーを作成する必要がある場合があります。
質問で説明されているシナリオを考えてみましょう。あるテーブル (table2) は別のテーブル (table1) との参照整合性を維持する必要がありますが、table1 で参照される列は主キーではありません。提供されているサンプル SQL コードは、作成しようとしているテーブルと外部キーの定義を示しています。
<code class="language-sql">CREATE TABLE table1 ( ID INT NOT NULL IDENTITY(1,1) PRIMARY KEY, AnotherID INT NOT NULL, SomeData VARCHAR(100) NOT NULL ) CREATE TABLE table2 ( ID INT NOT NULL IDENTITY(1,1) PRIMARY KEY, AnotherID INT NOT NULL, MoreData VARCHAR(30) NOT NULL, CONSTRAINT fk_table2_table1 FOREIGN KEY (AnotherID) REFERENCES table1 (AnotherID) )</code>
問題は、table1 の AnotherID 列が主キーではないことです。ほとんどのデータベース システムでは、外部キーは主キーまたは一意の制約を持つ列のみを参照できます。
この問題を解決するには、参照される列 (table1 の AnotherID) に一意制約が定義されていることを確認する必要があります。一意制約は行ごとに適用され、列の値がテーブルのすべての行で一意であることが保証されます。
table1のAnotherIDに一意制約を追加することで外部キー参照の候補となります。次の変更された SQL コードは、この修正を示しています:
<code class="language-sql">ALTER TABLE table1 ADD UNIQUE (AnotherID)</code>
これで、table2 に外部キー制約を正常に定義して、2 つのテーブル間の参照整合性を強制できるようになりました。
<code class="language-sql">ALTER TABLE table2 ADD CONSTRAINT FK_Table2_Table1 FOREIGN KEY (AnotherID) REFERENCES table1 (AnotherID)</code>
ただし、元の質問への回答が指摘しているように、一般的に主キーを候補キーとして使用することをお勧めします。主キーは自動的に一意として定義されるため、追加の制約は必要なく、外部キーの定義が簡素化されます。
以上が非主キー列を参照する外部キー制約を作成するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。