在資料庫設計中,強制外鍵約束以確保資料一致性通常是必要的。然而,在涉及多態性的場景中,外鍵可以引用多個相關表中的行,傳統的外鍵約束就顯得力不從心了。
在提供的範例中,comments 表包含一個 foreign_id 字段,該字段可以根據 model 字段引用不同的表(blogposts、picture 等)。為此,需要一個條件外鍵約束。
MySQL 本身並不支援條件外鍵約束。聲明一個根據條件引用不同表的外部鍵將違反關係資料庫設計原則。
一種更有效的方法,稱為“多態關聯”,涉及建立一個“超級表”,作為所有相關表的單一參考點。在這種情況下,可以實現以下結構:
<code class="language-sql">CREATE TABLE Commentable ( id SERIAL PRIMARY KEY ); CREATE TABLE Comments ( comment_id SERIAL PRIMARY KEY, foreign_id INT NOT NULL, ... FOREIGN KEY (foreign_id) REFERENCES Commentable(id) );</code>
每個內容類型(部落格文章、使用者圖片等)都變成 Commentable 超級表的子類型:
<code class="language-sql">CREATE TABLE BlogPosts ( blogpost_id INT PRIMARY KEY, -- 非自动生成 ... FOREIGN KEY (blogpost_id) REFERENCES Commentable(id) ); CREATE TABLE UserPictures ( userpicture_id INT PRIMARY KEY, -- 非自动生成 ... FOREIGN KEY (userpicture_id) REFERENCES Commentable(id) );</code>
向特定內容表插入資料需要先向 Commentable 表插入新行以獲得偽主鍵 id。然後,此 id 可用於特定內容表。
這種方法允許引用完整性,同時保持多態關聯所需的靈活性。
以上是如何在 MySQL 中實作多態關聯來處理條件外鍵?的詳細內容。更多資訊請關注PHP中文網其他相關文章!