我对外键的回忆

添加外键:(注意: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;

猜你喜欢

转载自blog.csdn.net/qq_36791569/article/details/80165084
今日推荐