Mysql外键设置中的CASCADE、NO ACTION、RESTRICT、SET NULL
2023-06-13 09:20:08 时间
今天在使用Navicat for mysql设计表时,在设置外键的时候,删除时和更新时两列有四个值可以选择:CASCADE、NO ACTION、RESTRICT、SET NULL,自己全亲自试了一遍,它们的区别如下:
CASCADE:父表delete、update的时候,子表会delete、update掉关联记录; SET NULL:父表delete、update的时候,子表会将关联记录的外键字段所在列设为null,所以注意在设计子表时外键不能设为not null; RESTRICT:如果想要删除父表的记录时,而在子表中有关联该父表的记录,则不允许删除父表中的记录; NO ACTION:同 RESTRICT,也是首先先检查外键;空、RESTRICT、NO ACTION 删除:从表记录不存在时,主表才可以删除,删除从表,主表不变。
更新:从表记录不存在时,主表菜可以更新,更新从表,主表不变。
CASCADE 删除:删除主表时自动删除从表。删除从表,主表不变。
更新:更新主表时自动更新从表。更新从表,主表不变。
SET NULL 删除:删除主表时自动更新从表为NULL,删除从表,主表不变。
更新:更新主表时自动更新从表值为NULL。更新从表,主表不变。
(1)在数据库bookshop中我新建了表a如下:
设置外键:
(2)在数据库bookshop中我新建了表b如下:
(3)给a、b表插入记录如下:
这里:a表id2字段为外键字段,参看b表的主键,所以b表是父表,a表是子表;然后分别在设置a表外键的时候设置不同的四个值,就可以得出我上述的结论。
到此这篇关于Mysql外键设置中的CASCADE、NO ACTION、RESTRICT、SET NULL的文章就介绍到这了,更多相关Mysql CASCADE NO ACTION RESTRICT SET NULL内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!
我想要获取技术服务或软件
服务范围:MySQL、ORACLE、SQLSERVER、MongoDB、PostgreSQL 、程序问题
服务方式:远程服务、电话支持、现场服务,沟通指定方式服务
技术标签:数据恢复、安装配置、数据迁移、集群容灾、异常处理、其它问题
本站部分文章参考或来源于网络,如有侵权请联系站长。
数据库远程运维 Mysql外键设置中的CASCADE、NO ACTION、RESTRICT、SET NULL
相关文章
- 研究MySQL下如何设置外键(mysql中如何定义外键)
- 密码MySQL安全设置——用户密码篇(mysql设置用户)
- MySQL编译参数查看指南(mysql编译参数查看)
- MySQL路由: 简易步骤引导你快速完成(mysql路由)
- Mysql官方手册:掌握完美数据库管理(mysql官方手册)
- MySQL查询:设置和使用默认值(mysql查询默认值)
- MySQL设置自增长字段值(mysql递增值)
- MySQL 多表查询语句详解(mysql多表查询语句)
- 如何设置MySQL自动关闭连接,避免不必要的资源浪费?(mysql自动关闭连接)
- MySQL视图实例简介(mysql视图实例)
- MySQL开发指南:达成更大的成功(mysql开发手册)
- MySQL命令行安装指南(mysql命令行安装)
- MySQL汉字拼音排序:一种实用的解决方案(mysql汉字拼音排序)
- 里MySQL安装位置及其重要性(mysql装在哪)
- MySQL如何创建表并设置编码格式(mysql创建表编码格式)
- MySQL数据库权限设置(mysql数据库赋予权限)
- MySQL中如何实现一对多关系(mysql中一对多)
- MySQL中如何使用SET (mysql中set @)
- MySQL中的Nullif函数处理空值的好帮手(mysql中nullif)
- C3PO构建MySQL连接的全新体验(c3po连接mysql)
- MySQL全局变量的设置和使用方法(mysql中全局变量)
- MySQL入门中的常见问题解析(mysql一些题目)
- MySQL自增长ID设置不为空(mysql不为空自增长)
- MySQL的字符集设置问题如何支持输入中文(mysql不能输汉字吗)
- MySQL上传最大值设置技巧(mysql上传最大值)
- 如何在MySQL中避免设置默认值(mysql不想设置默认值)