外键用来让两张表的数据之间建立连接,从而保证数据的一致性和完整性。
有一张学生表和班级表,学生表通过班级表的ID引用到该班级,从而进行关联,而通过外键约束可以保证数据的一致性完整性。
如学生ID18关联到课程ID1号,发生了关联并且使用了外键,这时删除课程表ID为1的情况下就会失败,因为有关联,这样就保证了数据的完整性。
新建表时添加
sql
CREATE TABLE orders (
order_id INT PRIMARY KEY,
customer_id INT,
order_date DATE,
FOREIGN KEY (customer_id) REFERENCES customers(customer_id)
);
已创建的表添加
ALTER TABLE 子表名称
ADD CONSTRAINT 外键约束名称
FOREIGN KEY (子表外键字段)
REFERENCES 父表名称(父表关联字段);
实例
ALTER TABLE students ADD CONSTRAINT students_classes FOREIGN KEY (classes) REFERENCES classes(id)
这时课程表为父表,学生表为子表
创建外键成功后,如果删除班级表,这时有学生关联着会删除失败,
DELETE FROM classes WHERE id=1
翻译过来
删除失败,外键约束
ALTER TABLE students DROP FOREIGN KEY 外键名称
NO ACTION(默认)
当在父表中删除/更新对应记录时,首先检查该记录是否有对应外键,如果有则不允许删除/更新。(与RESTRICT一致)
RESTRICT
当在父表中删除/更新对应记录时,首先检查该记录是否有对应外键,如果有则不允许删除/更新。(与NOACTION 致)
这两个是一样的
CASCADE
当在父表中删除/更新对应记录时,首先检查该记录是否有对应外键,如果有则也删除/更新外键在子表中的记录。也就是说会删除子表关联的数据
SET NULL
当在父表中删除对应记录时,首先检查该记录是否有对应外键,如果有则设置子表中该外键值为nul(这就要求该外键允许取nul)。删除父表的数据时候子表关联的数据会设置成null
SET DEFAULT
父表有变更时,子表将外键列设置成一个默认的值(Innodb不支持)