MySQL中的外键(Foreign Key)是一种数据库约束,用于建立两个表之间的链接。外键约束确保了引用完整性,即在一个表中的值必须是另一个表中的值,或者为NULL。
MySQL中的外键约束主要有以下几种类型:
外键约束常用于以下场景:
假设有两个表:customers
和 orders
,其中 orders
表中的 customer_id
列引用 customers
表中的 id
列。
customers
表CREATE TABLE customers (
id INT AUTO_INCREMENT PRIMARY KEY,
name VARCHAR(100) NOT NULL
);
orders
表并设置外键CREATE TABLE orders (
id INT AUTO_INCREMENT PRIMARY KEY,
order_date DATE NOT NULL,
customer_id INT,
FOREIGN KEY (customer_id) REFERENCES customers(id)
);
原因:通常是因为引用的值在主表中不存在。
解决方法:
ON DELETE CASCADE
或 ON UPDATE CASCADE
。CREATE TABLE orders (
id INT AUTO_INCREMENT PRIMARY KEY,
order_date DATE NOT NULL,
customer_id INT,
FOREIGN KEY (customer_id) REFERENCES customers(id) ON DELETE CASCADE
);
SET FOREIGN_KEY_CHECKS = 0;
-- 执行插入或更新操作
SET FOREIGN_KEY_CHECKS = 1;
希望这些信息对你有所帮助!如果有更多问题,请随时提问。
领取专属 10元无门槛券
手把手带您无忧上云