mysql中外键约束如何使用_mysql FOREIGN KEY操作

来源:这里教程网 时间:2026-02-28 20:26:12 作者:

在 MySQL 中,外键约束(FOREIGN KEY)用于维护表之间的引用完整性。它确保一个表中的数据与另一个表中的主键或唯一键保持一致,防止出现“孤立”的记录。

什么是外键约束

外键是一个表中的字段(或字段组合),它指向另一个表的主键或唯一键。通过外键约束,可以保证数据的一致性和有效性。例如,订单表中的用户 ID 必须存在于用户表中。

创建外键的语法

可以在创建表时定义外键,也可以在已有表上添加外键约束。

1. 创建表时添加外键:

CREATE TABLE users (
    id INT PRIMARY KEY AUTO_INCREMENT,
    name VARCHAR(50)
);
CREATE TABLE orders (
    id INT PRIMARY KEY AUTO_INCREMENT,
    user_id INT,
    order_date DATE,
    FOREIGN KEY (user_id) REFERENCES users(id)
        ON DELETE CASCADE
        ON UPDATE CASCADE
);

说明:

REFERENCES users(id):表示 orders 表中的 user_id 字段引用 users 表的 id 字段。 ON DELETE CASCADE:当 users 表中某条记录被删除时,orders 表中对应的记录也会自动删除。 ON UPDATE CASCADE:当 users 表中的 id 被修改时,orders 表中的 user_id 也会自动更新。 2. 对已有表添加外键:

ALTER TABLE orders
ADD CONSTRAINT fk_user_id
FOREIGN KEY (user_id) REFERENCES users(id)
ON DELETE SET NULL
ON UPDATE CASCADE;

说明:

ADD CONSTRAINT fk_user_id:为外键命名,便于后续管理(如删除)。 ON DELETE SET NULL:当被引用的记录删除时,将外键字段设为 NULL(该字段需允许 NULL)。

外键操作的行为选项

外键支持以下几种行为控制:

ON DELETE CASCADE:删除父表记录时,子表相关记录也被删除。 ON DELETE SET NULL:删除父表记录时,子表外键字段设为 NULL。 ON DELETE RESTRICTNO ACTION:若子表有对应记录,则禁止删除父表记录。 ON UPDATE CASCADE:更新父表主键时,子表外键自动更新。 ON UPDATE SET NULL:更新父表主键时,子表外键设为 NULL。

查看和删除外键

要查看表的外键约束:

SHOW CREATE TABLE orders;

或查询信息模式:

SELECT 
  CONSTRAINT_NAME, 
  COLUMN_NAME, 
  REFERENCED_TABLE_NAME, 
  REFERENCED_COLUMN_NAME 
FROM 
  INFORMATION_SCHEMA.KEY_COLUMN_USAGE 
WHERE 
  TABLE_NAME = 'orders' 
  AND REFERENCED_TABLE_NAME IS NOT NULL;

删除外键约束:

ALTER TABLE orders DROP FOREIGN KEY fk_user_id;

注意:删除后如果需要删除索引,还需单独执行 DROP INDEX。

基本上就这些。合理使用外键能有效防止脏数据,但也要注意性能影响,特别是在高并发写入场景下。设计时结合业务逻辑选择合适的 ON DELETE 和 ON UPDATE 策略。不复杂但容易忽略。

相关推荐

热文推荐