mysql设置外键怎么写-mysql教程

admin2年前 (2024-06-05)基础运维知识408
点击下载TXT

如何设置 MySQL 外键

在 MySQL 中设置外键可以确保数据完整性,它强制执行父子表之间的引用关系。

语法

ALTER TABLE 子表 ADD FOREIGN KEY (子表列) REFERENCES 父表 (父表列)
登录后复制

步骤

  1. 创建父表

    首先,创建包含父数据的父表:

    CREATE TABLE 父表 (
      id INT NOT NULL AUTO_INCREMENT,
      name VARCHAR(255) NOT NULL,
      PRIMARY KEY (id)
    );
    登录后复制
  2. 创建子表

    接下来,创建包含子数据的子表,并添加外键列:

    CREATE TABLE 子表 (
      id INT NOT NULL AUTO_INCREMENT,
      name VARCHAR(255) NOT NULL,
      父表_id INT NOT NULL,
      FOREIGN KEY (父表_id) REFERENCES 父表 (id),
      PRIMARY KEY (id)
    );
    登录后复制
  3. 插入数据

    插入数据时,确保子表的 父表_id 列值引用父表中的现有记录:

    INSERT INTO 父表 (name) VALUES ('父表记录 1');
    INSERT INTO 子表 (name, 父表_id) VALUES ('子表记录 1', 1);
    登录后复制

优势

设置外键有以下优势:

  • 数据完整性:确保子表中的数据与父表中的数据一致。
  • 级联操作:当父表记录被删除或更新时,级联操作允许自动更新或删除子表中的相关记录。
  • 查询优化:通过使用外键索引,可以优化涉及子表和父表联接的查询。

提示

  • 父表中的列类型应与子表中的外键列类型匹配。
  • 父表中的列应具有唯一约束或主键。
  • 外键列在子表中通常非空。

相关文章

mysql自增id怎么办-mysql教程

MySQL 的自增 ID 机制 MySQL 数据库使用自增 ID 机制为新插入的行自动生成唯一的 ID 值。这个 ID 值通常是一个递增的整数,例如 1、2、3 等。自增 ID 机制在许多情况下都非...

mysql怎么导入mdf文件-mysql教程

如何将 MDF 文件导入 MySQL MySQL 无法直接导入 Microsoft SQL Server (MSSQL) 的 MDF 文件。但是,可以通过以下步骤将 MDF 文件中的数据迁移到 My...

mysql停止服务怎么打开-mysql教程

如何重启 MySQL 服务 1. 确认 MySQL 服务已停止 通过命令 sudo systemctl status mysql 检查服务状态。 2. 启动 MySQL 服务 使用命令 sudo s...

mysql锁怎么看-mysql教程

如何在 MySQL 中查看锁 在 MySQL 中,锁是一项重要的机制,它允许系统控制对数据的并发访问。当查询或事务对数据进行修改时,MySQL 会自动获取锁来防止其他查询或事务同时修改相同的数据。...

mysql时间格式化怎么用-mysql教程

MySQL 时间格式化 MySQL 中的时间格式化功能允许用户将时间值转换为可读且特定的文本字符串。 如何使用时间格式化 要格式化时间值,可以使用以下语法: DATE_FORMAT(datetime...

mysql怎么查询表中数据-mysql教程

如何使用 MySQL 查询表中数据 在 MySQL 中查询表数据有多种方法,本文将介绍常用的几种方法: 使用 SELECT 语句 最常用的查询方法是使用 SELECT 语句,其语法如下: SELEC...

发表评论

访客

◎欢迎参与讨论,请在这里发表您的看法和观点。