翼度科技»论坛 编程开发 mysql 查看内容

MySQL外键约束的删除和更新总结

9

主题

9

帖子

27

积分

新手上路

Rank: 1

积分
27
外键约束


外键约束的删除/更新行为

  1. 行为
复制代码
说明
  1. NO ACTION
复制代码
当在父表中删除/更新对应记录时,首先检查该记录是否有对应外键,如果有则不允许删除/更新。(与RESTRICT一致)
  1. RESTRICT
复制代码
当在父表中删除/更新对应记录时,首先检查该记录是否有对应外键,如果有则不允许删除/更新。(与NOT ACTION一致)
  1. CASCADE
复制代码
当在父表中删除/更新对应记录时,首先检查该记录是否有对应外键,如果有,则也删除/更新外键在子表总的记录。
  1. SET NULL
复制代码
当在父表中删除对应记录时,首先检查该记录是否有对应外键,如果有则设置该子表中该外键值为null(这就要求该外键允许取null)。
  1. SET DEFAULT
复制代码
父表有变更时,子表将外键列设置为一个默认的值(innodb不支持)alter table 表名 add constraint 外键名称 references 主表名(主表字段名) on update cascade on delete cascade
  1. -- 添加外键约束并指定外键的删除和更新行为
  2. alter table emp add constraint fk_emp_dept_id foreign key (dept_id) references dept(id) on update cascade on delete cascade ;
复制代码



将父表dept中的研发部的id改为6,emp表中的id也会跟着改变

当我们删除父表中id为6,我们可以看到子表emp中存在外键关联的数据也会被删除。 说明:如果子表与父表存在外键关联,删除父表的数据也会影响子表。


演示2:

现在我们先删除刚刚创建的emp和dept这两张表,然后重新创建。然后通过命令行进行emp表的外键的添加。
  1. -- 添加外键约束并指定外键的删除和更新行为

  2. alter table emp add constraint fk_emp_dept_id foreign key (dept_id) references dept(id) on update set null on delete set null ;
复制代码
测试:

删除dept表中的第一行,然后刷新,我们可以看到emp表中的id为1的数据全部置为null了。



通过图形化界面创建




选中预修改的表,然后点击modify table,再点击foreign keys ,双击命令,我们可以在这里修改更新和删除的规则,改完以后点击execute执行即可.

总结


以上就是MySQL外键约束的删除和更新总结的详细内容,更多关于MySQL外键约束的资料请关注脚本之家其它相关文章!

来源:https://www.jb51.net/database/315724ihm.htm
免责声明:由于采集信息均来自互联网,如果侵犯了您的权益,请联系我们【E-Mail:cb@itdo.tech】 我们会及时删除侵权内容,谢谢合作!

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

x

举报 回复 使用道具