MySQL中的主键(Primary Key)和外键(Foreign Key)是关系型数据库中用于确保数据引用完整性的约束。
假设我们有两个表:customers
和 orders
,其中 orders
表通过 customer_id
字段引用 customers
表的 id
字段。
-- 创建 customers 表
CREATE TABLE customers (
id INT AUTO_INCREMENT PRIMARY KEY,
name VARCHAR(100) NOT NULL,
email VARCHAR(100) UNIQUE NOT NULL
);
-- 创建 orders 表,并添加外键约束
CREATE TABLE orders (
order_id INT AUTO_INCREMENT PRIMARY KEY,
customer_id INT,
order_date DATE NOT NULL,
FOREIGN KEY (customer_id) REFERENCES customers(id)
);
原因:
解决方法:
-- 示例:修正数据类型不匹配的问题
ALTER TABLE orders MODIFY COLUMN customer_id INT;
原因:
解决方法:
-- 示例:设置级联删除
CREATE TABLE orders (
order_id INT AUTO_INCREMENT PRIMARY KEY,
customer_id INT,
order_date DATE NOT NULL,
FOREIGN KEY (customer_id) REFERENCES customers(id) ON DELETE CASCADE
);
通过以上信息,您可以更好地理解MySQL中主键和外键的概念、优势、类型、应用场景以及常见问题的解决方法。
领取专属 10元无门槛券
手把手带您无忧上云