登录
首页 >  数据库 >  MySQL

Mysql入门第五课《外键约束》

来源:SegmentFault

时间:2023-01-21 10:00:24 211浏览 收藏

大家好,今天本人给大家带来文章《Mysql入门第五课《外键约束》》,文中内容主要涉及到MySQL、PHP、Node.js、javascript,如果你对数据库方面的知识点感兴趣,那就请各位朋友继续看下去吧~希望能真正帮到你们,谢谢!

原在我的 Github 上,欢迎订阅。

其他文章:

但是我问过同事,他们现在开发中不会使用外键约束,主要原因是数据量大或请求很频繁时会导致一些性能问题,实际开发中是通过业务代码来代替外键约束的功能。

但这不代表不需要学它,如果你的项目数据量不是很大,用外键约束还是非常方便的。

什么是外键

通过之前学习和练习,外键其实已经出现过,比如在

ALTER TABLE student ADD CONSTRAINT student_class FOREIGN KEY (class_id) REFERENCES class(id);

解析一下上面的语句:

  • ALTER TABLE student :对 student 表进行操作
  • ADD CONSTRAINT student_class:添加约束,名称为 student_class
  • FOREIGN KEY (class_id):指定外键是 class_id
  • REFERENCES class(id):关联(参考) class 表的 id

看下结果:

为了好理解再看下 ER 图:

ON DELETE 和 ON UPDATE

ON DELETE 和 ON UPDATE 表示删除时 和 更新时 要处理的方式。

上面图里有

DELETE FROM class WHERE id=1;

更新也是一样:

UPDATE class SET id=10    WHERE id=1;

CASCADE

CASCADE: 对父表删除或更新时,子表同时删除或更新

我们来试一把。
先修改外键约束:

ALTER TABLE student DROP FOREIGN KEY student_class;

ALTER TABLE student ADD 
CONSTRAINT student_class 
FOREIGN KEY (class_id) 
REFERENCES class(id)
ON DELETE CASCADE
ON UPDATE CASCADE;


可以看到已经改为
DELETE FROM class WHERE id=2;

然后来看看班级和学生:


班级表中 id=2 的数据已经没有了

再看看学生表:


class_id=2 的学生也一起删了

现在修改一下试试,我们把

UPDATE class SET id=10 WHERE id=1;

修改成功:

再看看原本

ALTER TABLE student DROP FOREIGN KEY student_class;

ALTER TABLE student 
ADD CONSTRAINT student_class 
FOREIGN KEY (class_id) 
REFERENCES class(id) 
ON DELETE SET NULL
ON UPDATE SET NULL;

为了演示方便,在

UPDATE class SET id=100 WHERE id=10;

上面语句是把

id=10
的班级改为
id=100

班级修改成功了,再看看这个班级下的学生:


原本
class_id=10
的学生现在也没有了班级,
class_id
也置为
NULL
了。

总结

本篇学习了什么是外键约束,以及外键约束的几个处理方式:

  • NO ACTION 或 RESTRICT:对父表删除或更新时,必须把子表处理完才能删除或更新主表数据
  • CASCADE:对父表删除或更新时,子表同时删除或更新
  • SET NULL:对父表删除或更新时,子表设置为NULL

默认为 RESTRICT 。

今天关于《Mysql入门第五课《外键约束》》的内容介绍就到此结束,如果有什么疑问或者建议,可以在golang学习网公众号下多多回复交流;文中若有不正之处,也希望回复留言以告知!

声明:本文转载于:SegmentFault 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>