ホームページ >データベース >mysql チュートリアル >非主キー列を参照する外部キー制約を作成するにはどうすればよいですか?

非主キー列を参照する外部キー制約を作成するにはどうすればよいですか?

Barbara Streisand
Barbara Streisandオリジナル
2025-01-15 09:27:42443ブラウズ

How Can I Create a Foreign Key Constraint Referencing a Non-Primary Key Column?

外部キーを使用して非主キー列の参照整合性を維持します

データベース システムでは、外部キーを使用してテーブル間の関係を確立し、参照整合性を強制します。通常、外部キーは他のテーブルの主キーを参照して、依存テーブル内のデータの一貫性を確保します。ただし、場合によっては、主キー以外の列を指す外部キーを作成する必要がある場合があります。

質問で説明されているシナリオを考えてみましょう。あるテーブル (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 サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。