首頁 >資料庫 >mysql教程 >如何建立引用非主鍵列的外鍵約束?

如何建立引用非主鍵列的外鍵約束?

Barbara Streisand
Barbara Streisand原創
2025-01-15 09:27:42444瀏覽

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 中的外鍵約束,從而強制執行兩個表之間的參照完整性。

<code class="language-sql">ALTER TABLE table2
ADD CONSTRAINT FK_Table2_Table1 FOREIGN KEY (AnotherID) REFERENCES table1 (AnotherID)</code>

但是,正如對原始問題的答案所指出的那樣,通常建議使用主鍵作為候選鍵。主鍵會自動定義為唯一,無需額外的約束,並簡化外鍵定義。

以上是如何建立引用非主鍵列的外鍵約束?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn