添加外键:(注意:constraint前面没得add,add是alter的时候才会有的)
CONSTRAINT stu_class_fk
FOREIGN KEY(stu_id)
REFERENCES stu_class(id)
ON UPDATE CASCADE
ON DELETE CASCADE
在添加外键的时候,必须保证外键到的主表的字段为unique的,或者是primary key。
CREATE TABLE stu_class(
id INT UNIQUE
);
CREATE TABLE student(
class_id INT,
CONSTRAINT stu_class_fk
FOREIGN KEY(class_id)
REFERENCES stu_class(id)
ON UPDATE CASCADE
ON DELETE CASCADE
);
INSERT INTO stu_class VALUE(1), (2), (3);
INSERT INTO student VALUE(1), (1), (2), (2), (3), (3);
-- 删除主表中的数据,因为级联删除,从表中的数据没有了。
DELETE FROM stu_class WHERE id = 1;
-- 删除从表中的数据,主表并不会受到影响
DELETE FROM student WHERE class_id = 2;
-- 修改主表中的数据,因为级联修改,从表中的数据一起修改了。
UPDATE stu_class SET id = 5 WHERE id = 3;
-- 从表中的数据是不能修改的!
UPDATE student SET id = 2 WHERE id = 5;
-- 包括很多时候我们设置了主键自增长,没有办法truncate从表中的自增长记录
-- 只能通过先设置外键为0,再设置外键为1
-- 额外补充:其实在mysql中是没有boolean 类型的,所有boolean的值都是被转化成0和1:0f,1t。
SET FOREIGN_KEY_CHECKS = 0;
SET FOREIGN_KEY_CHECKS = 1;