![](https://img-home.csdnimg.cn/images/20220524100510.png#pic_center)](https://img-blog.csdnimg.cn/21dd41dce63a4f2da07b9d879ad0120b.png#pic_center)
🌈个人主页: Aileen_0v0
🔥热门专栏: 华为鸿蒙系统学习|计算机网络|数据结构与算法
💫个人格言:“没有罗马,那就自己创造罗马~”
外键约束
外键约束的删除/更新行为
行为 |
说明 |
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 ;
![在这里插入图片描述](https://img-blog.csdnimg.cn/direct/4fe2e2f08b0e4f3f9f9303518da627cb.png)
![在这里插入图片描述](https://img-blog.csdnimg.cn/direct/a66d6e00905544318c06e8e5e25aa763.png)
![在这里插入图片描述](https://img-blog.csdnimg.cn/direct/504deb40a6754af3b0d298ff711d81c7.png)
将父表dept中的研发部的id改为6,emp表中的id也会跟着改变 |
![在这里插入图片描述](https://img-blog.csdnimg.cn/direct/af191024a5e14947bc87634ee52ed607.png)
当我们删除父表中id为6,我们可以看到子表emp中存在外键关联的数据也会被删除。 说明:如果子表与父表存在外键关联,删除父表的数据也会影响子表。 |
![在这里插入图片描述](https://img-blog.csdnimg.cn/direct/bedf79a3b0c1454b9201884c7031942e.png)
演示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了。 |
![在这里插入图片描述](https://img-blog.csdnimg.cn/direct/6fd1bd48a978472a9686643d5cc76121.png)
![在这里插入图片描述](https://img-blog.csdnimg.cn/direct/3c23c0b3355c49cfa55ca8a0b21d02d2.png)
通过图形化界面创建
![在这里插入图片描述](https://img-blog.csdnimg.cn/direct/b47996b85d0c49419a8a94a7d484c2fd.png)
![在这里插入图片描述](https://img-blog.csdnimg.cn/direct/b245020071fe44cf9696b6367dcca596.png)
![在这里插入图片描述](https://img-blog.csdnimg.cn/direct/8c3c832d36054d13abdb9b90c496f060.png)
选中预修改的表,然后点击modify table,再点击foreign keys ,双击命令,我们可以在这里修改更新和删除的规则,改完以后点击execute执行即可. |
总结
![在这里插入图片描述](https://img-blog.csdnimg.cn/direct/7a16623dc2694bbe9c8fde74d8785bb9.png)
![](https://img-home.csdnimg.cn/images/20220524100510.png#pic_center)](https://img-blog.csdnimg.cn/0ee6c4ec414740b0a0404c5161cdadc7.gif#pic_center)
![](https://img-home.csdnimg.cn/images/20220524100510.png#pic_center)](https://img-blog.csdnimg.cn/cc002cbd5c414c5393e19c5e0a0dbf20.gif#pic_center#pic_center)