在数据库设计中,强制外键约束以确保数据一致性通常是必要的。然而,在涉及多态性的场景中,外键可以引用多个相关表中的行,传统的外键约束就显得力不从心了。
在提供的示例中,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中文网其他相关文章!