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

06-01 1402阅读

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

🌈个人主页: Aileen_0v0

🔥热门专栏: 华为鸿蒙系统学习|计算机网络|数据结构与算法

​💫个人格言:“没有罗马,那就自己创造罗马~”

文章目录

  • `外键约束`
    • `外键约束的删除/更新行为`
    • `演示2:`
    • `测试:`
    • `通过图形化界面创建`
    • `总结`

      外键约束

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

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

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

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

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

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

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

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

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


      演示2:

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

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

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


      通过图形化界面创建

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

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

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

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

      总结

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

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

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

免责声明:我们致力于保护作者版权,注重分享,被刊用文章因无法核实真实出处,未能及时与作者取得联系,或有版权异议的,请联系管理员,我们会立即处理! 部分文章是来自自研大数据AI进行生成,内容摘自(百度百科,百度知道,头条百科,中国民法典,刑法,牛津词典,新华词典,汉语词典,国家院校,科普平台)等数据,内容仅供学习参考,不准确地方联系删除处理! 图片声明:本站部分配图来自人工智能系统AI生成,觅知网授权图片,PxHere摄影无版权图库和百度,360,搜狗等多加搜索引擎自动关键词搜索配图,如有侵权的图片,请第一时间联系我们。

目录[+]

取消
微信二维码
微信二维码
支付宝二维码