这是数据库外键定义的一个可选项,用来设置当主键表中的被参考列的数据发生变化时,外键表中响应字段的变换规则的。update 则是主键表中被参考字段的值更新,delete是指在主键表中删除一条记录:
on update 和 on delete 后面可以跟的词语有四个
no action , set null , set default ,cascade

no action 表示 不做任何操作,
set null 表示在外键表中将相应字段设置为null
set default 表示设置为默认值(restrict)

cascade 表示级联操作,就是说,如果主键表中被参考字段更新,外键表中也更新,主键表中的记录被删除,外键表中改行也相应删除

以下是4张表:

  1. CREATE TABLE `groups` (
  2. `groupid` bigint(20) unsigned NOT NULL,
  3. `name` varchar(64) NOT NULL DEFAULT '',
  4. `internal` int(11) NOT NULL DEFAULT '0',
  5. `flags` int(11) NOT NULL DEFAULT '0',
  6. PRIMARY KEY (`groupid`),
  7. KEY `groups_1` (`name`)
  8. ) ENGINE=InnoDB DEFAULT CHARSET=utf8;
  1. CREATE TABLE `scripts` (
  2. `scriptid` bigint(20) unsigned NOT NULL,
  3. `name` varchar(255) NOT NULL DEFAULT '',
  4. `command` varchar(255) NOT NULL DEFAULT '',
  5. `host_access` int(11) NOT NULL DEFAULT '2',
  6. `usrgrpid` bigint(20) unsigned DEFAULT NULL,
  7. `groupid` bigint(20) unsigned DEFAULT NULL,
  8. `description` text NOT NULL,
  9. `confirmation` varchar(255) NOT NULL DEFAULT '',
  10. `type` int(11) NOT NULL DEFAULT '0',
  11. `execute_on` int(11) NOT NULL DEFAULT '1',
  12. PRIMARY KEY (`scriptid`),
  13. KEY `scripts_1` (`usrgrpid`),
  14. KEY `scripts_2` (`groupid`),
  15. CONSTRAINT `c_scripts_1` FOREIGN KEY (`usrgrpid`) REFERENCES `usrgrp` (`usrgrpid`) ON DELETE CASCADE ON UPDATE CASCADE,
  16. CONSTRAINT `c_scripts_2` FOREIGN KEY (`groupid`) REFERENCES `groups` (`groupid`)
  17. ) ENGINE=InnoDB DEFAULT CHARSET=utf8;
  1. CREATE TABLE `users_groups` (
  2. `id` bigint(20) unsigned NOT NULL,
  3. `usrgrpid` bigint(20) unsigned NOT NULL,
  4. PRIMARY KEY (`id`),
  5. UNIQUE KEY `users_groups_1` (`usrgrpid`),
  6. CONSTRAINT `c_users_groups_1` FOREIGN KEY (`usrgrpid`) REFERENCES `usrgrp` (`usrgrpid`) ON DELETE CASCADE ON UPDATE CASCADE
  7. ) ENGINE=InnoDB DEFAULT CHARSET=utf8;
  1. CREATE TABLE `usrgrp` (
  2. `usrgrpid` bigint(20) unsigned NOT NULL,
  3. `name` varchar(64) NOT NULL DEFAULT '',
  4. `gui_access` int(11) NOT NULL DEFAULT '0',
  5. `users_status` int(11) NOT NULL DEFAULT '0',
  6. `debug_mode` int(11) NOT NULL DEFAULT '0',
  7. PRIMARY KEY (`usrgrpid`),
  8. KEY `usrgrp_1` (`name`)
  9. ) ENGINE=InnoDB DEFAULT CHARSET=utf8;



1.

users_groups表引用外键 usrgrp.usrgrpid 并设置 ON DELETE CASCADE ON UPDATE CASCADE

scripts表引用外键 usrgrp.usrgrpid 并设置 ON
DELETE CASCADE ON UPDATE CASCADE

所以对已引用usrgrp.usrgrpid字段的修改对应引用的表也会修改

2.

scripts.groupid 引用groups.groupid 没有设置操作关联属性

CONSTRAINT `c_scripts_2` FOREIGN KEY (`groupid`) REFERENCES `groups` (`groupid`)

对已引用groups.grouppid字段不可修改

sql 外键 on update cascade 和 on delete cascade 作用区别?的更多相关文章

  1. 主外键 设置 on update cascade 和on delete cascade 的区别

    on update cascade 和on delete cascade 的区别 这是数据库外键定义的一个可选项,用来设置当主键表中的被参考列的数据发生变化时,外键表中响应字段的变换规则的.updat ...

  2. SQL 外键

    先新建2个表,写入数据 -- 创建测试主表. ID 是主键. CREATE TABLE test_main ( id INT, value ), PRIMARY KEY(id) ); -- 创建测试子 ...

  3. My SQL外键约束

    外键约束对子表的含义:如果在父表中找不到对应的候选键,则不能对子表进行insert/update操作 外键约束对父表的含义:在父表上进行update/delete以更新或删除在子表中有一条或多条对应匹 ...

  4. Oracle SQL 外键测试

    测试SQL 创建SQL     t1为主表      t2为子表 create table t1(insert_date number,id int) create table t2(insert_d ...

  5. SQL外键的作用

    貌似很有用,但没有真正用过: SQL的主键和外键的作用: 外键取值规则:空值或参照的主键值. (1)插入非空值时,如果主键表中没有这个值,则不能插入. (2)更新时,不能改为主键表中没有的值. (3) ...

  6. 两句话概括“sql外键”

    外键的使用就是: 1.外键表可以删除,外键表删完了 才能删主键表2.添加的时候不能添加在主键没有的内容

  7. 数据库 SQL 外键约束 多表查询

    多表设计与多表查询 1.外键约束        表是用来保存现实生活中的数据的,而现实生活中数据和数据之间往往具有一定的关系,我们在使用表来存储数据时,可以明确的声明表和表之前的依赖关系,命令数据库来 ...

  8. 关于sql 外键的讨论。

    外键是否采用看业务应用场景,以及开发成本的,大致列下什么时候适合,什么时候不适合使用: 1. 互联网行业应用不推荐使用外键: 用户量大,并发度高,为此数据库服务器很容易成为性能瓶颈,尤其受IO能力限制 ...

  9. SQL外键约束

    1.查询表已有的外键 select name from sys.foreign_key_columns f join sys.objects o on f.constraint_object_id=o ...

随机推荐

  1. Mars视频笔记——Animation

    Animations的使用(1) 什么是Animations 提供了一系列的动画效果,可以应用在绝大多数控件中 Animations的分类 1 Tweened Animations 渐变动画 提供了旋 ...

  2. 从零开始入门 K8s| 阿里技术专家详解 K8s 核心概念

    作者| 阿里巴巴资深技术专家.CNCF 9个 TCO 之一 李响 一.什么是 Kubernetes Kubernetes,从官方网站上可以看到,它是一个工业级的容器编排平台.Kubernetes 这个 ...

  3. Java 截取字符串中指定数据及之后数据

    String resCallBackJson="12556{1{{{456858585{";        resCallBackJson = resCallBackJson.su ...

  4. 将字符串转换成json格式

    1.引入json依赖,在pom.xml文件里添加如下内容 <!--Json array start --> <dependency> <groupId>common ...

  5. 【linux】【jenkins】自动化运维七 整合sonarqube代码审查

    1.安装插件:SonarQube Scanner for Jenkins 插件安装教程参考:https://www.cnblogs.com/jxd283465/p/11542680.html 2.So ...

  6. Autofac的AOP面向切面编程研究

    *:first-child { margin-top: 0 !important; } .markdown-body>*:last-child { margin-bottom: 0 !impor ...

  7. Scrapy项目 - 实现斗鱼直播网站信息爬取的爬虫设计

    要求编写的程序可爬取斗鱼直播网站上的直播信息,如:房间数,直播类别和人气等.熟悉掌握基本的网页和url分析,同时能灵活使用Xmind工具对Python爬虫程序(网络爬虫)流程图进行分析.   一.项目 ...

  8. 2017春季_京东_Java后端研发岗面经

    纸上得来终觉浅,绝知此事要躬行  ——2017春季Java后端研发工程师面试心得 收获offer:上海汉得+北京中科软+成都百词斩+成都诺基亚研发中心+清华大学计算机研究所等offer.阿里一面猝.京 ...

  9. vue 引入 fontawesome 报错 Could not find one or more icon(s) 解决

    在 vue 项目中引用 fontawesome , 按照官方说明如下步骤操作 1. 终端中执行 $ npm i --save @fortawesome/fontawesome-svg-core $ n ...

  10. HttpClient连接池的一些思考

    前言 使用apache的httpclient进行http的交互处理已经很长时间了,而httpclient实例则使用了http连接池,想必大家也没有关心过连接池的管理.事实上,通过分析httpclien ...