海印网
海印网

mysql创建表外键怎么写

admin数码90

在 mysql 中,可通过以下步骤创建表外键:创建父表和子表,并确保父表存在相应列。使用 foreign key 约束将子表中的列与父表中的列关联。可选地指定级联操作,定义删除或更新父表记录时对子表记录的影响。运行查询检查外键约束是否已正确应用。

mysql创建表外键怎么写-第1张图片-海印网

如何使用 MySQL 创建表外键

在 MySQL 中,外键约束用于确保子表中的记录与父表中的相关记录相对应。它有助于维护数据一致性和完整性。以下是创建外键的步骤:

1. 创建父表和子表

首先,创建包含外键列的子表。确保父表中存在相应的列。例如:

<code class="sql">CREATE TABLE parent_table (
  id INT NOT NULL,
  name VARCHAR(255)
);

CREATE TABLE child_table (
  id INT NOT NULL,
  parent_id INT,
  name VARCHAR(255)
);</code>

登录后复制

2. 创建外键约束

在子表中使用 FOREIGN KEY 约束将子表中的 parent_id 列与父表中的 id 列关联起来。例如:

<code class="sql">ALTER TABLE child_table
ADD FOREIGN KEY (parent_id) REFERENCES parent_table (id);</code>

登录后复制

3. 指定级联操作(可选)

级联操作定义当父表中的记录被删除或更新时,外键约束如何影响子表中的相关记录。您可以使用 ON DELETEON UPDATE 子句指定这些操作。例如:

<code class="sql">ALTER TABLE child_table
ADD FOREIGN KEY (parent_id) REFERENCES parent_table (id)
ON DELETE CASCADE
ON UPDATE RESTRICT;</code>

登录后复制

该示例指定:

  • 当父表中引用的父记录被删除时,将从子表中级联删除相关子记录。
  • 当父表中的引用的父记录被更新时,将阻止更新。

4. 检查约束

创建外键约束后,运行以下查询检查约束是否已应用:

<code class="sql">SELECT * FROM child_table
WHERE parent_id NOT IN (SELECT id FROM parent_table);</code>

登录后复制

如果查询返回结果,则表明子表中存在没有父记录相对应的记录,外键约束未正确应用。

以上就是mysql创建表外键怎么写的详细内容,更多请关注其它相关文章!

Tags: 表记级联

Sorry, comments are temporarily closed!