在 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 RESTRICT 或 NO 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 策略。不复杂但容易忽略。
