使用外鍵維護非主鍵列的參考完整性
在資料庫系統中,外鍵用於建立表之間的關係並強制執行參照完整性。通常,外鍵會引用其他表中的主鍵,以確保從屬表中的資料一致。但是,在某些情況下,可能需要建立指向非主鍵列的外鍵。
讓我們考慮問題中描述的場景,其中一個表 (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中文網其他相關文章!