在建表的时候时候,可以对于删除delete、修改update设置为级联。用一个例子先说明外键级联级联的概念

假如数据库中本以存在一张usertable如下:

此user表非常简单,id为主键。

下面我将新建一张cascade_test表如下,这里的user_id与usertable的主键id形成参照完整性,并同时建立删除与修改的级联:

如果用SQL语句建立上图的表则如下:

CREATE TABLE `test`.`cascade_test` (

`id` INTEGER UNSIGNED NOT NULL auto_increment,

`content` TEXT,

`user_id` INTEGER UNSIGNED, -- 由于usertable的主键是INTEGER UNSIGNED,这里必须同为这样类型,键值对应

PRIMARY KEY (`id`),

CONSTRAINT `FK_cascade_test_1` FOREIGN KEY `FK_cascade_test_1` (`user_id`)

REFERENCES `test`.`usertable`(`id`)

ON DELETE CASCADE

ON UPDATE CASCADE

)

ENGINE = InnoDB; -- 数据库引擎设置,可以没有

比起普通设置外键的语句,在其下多出了两个级联的声明,ON DELETE CASCADE、ON UPDATE CASCADE

设置级联与不设置级联,在参照完整性上是没有区别的。

user的id类型是怎么cascade_test的user_id类型就应该怎么样,这里需要严格照抄,由于user的id设置为无符号整形,这里cascade_test的user_id还不能是整形,一定要特意声明为无符号整形,否则会出现如下的[Err] 1005 - Can't create table 'xx' (errno: 150),其实150页就是参照完整性错误。

之后,在新建出来的cascade_test插入如下一些数据:

同样地,由于参照完整性的存在,cascade_test的user_id的取值范围还需要在user的id现有的值来取。

设置级联与不设置级联唯一的区别,就是我们在删除user的id中数据的同时,同样会删除cascade_test的user_id的所有有关字段。修改级联同样如此。

比如将user中id为6的项删除,也就是执行如下的语句:

delete from usertable where id=6

运行效果如下图:

usertable中id=6的项被删除是肯定的,

由于删除级联的存在:cascade_test中user_id=6的项通通被删除。

如果不设置级联,在usertable中id=6的项被删除的同时,cascade_test中user_id=6的项是不会删除的。造成了一定参照完整性的缺失。

下面说说级联的劣势:

这看来似乎很强大的样子,尤其是在网页编程的时候,就不用写这么多删除语句了,仅仅是删除一个主键,就能把所有涉及的项删除

但是,在你的工程足够的时候,这样的删除会很慢,实质上造成了表与表之间的耦合。远远比不删新增加一个isDel的项,使用标志删除的方式,查表的时候仅查询isDel=false的项。其实delete语句在网页的编程的时间根本就是可以扔掉的。这样还有个好处,出现在需要找被删除的旧数据的时候,绝对可以找回来。

这样你的网页的运行速度会大大加快,否则如果一旦执行级联删除的语句,会涉及的表足够多的时候,执行起来将会足够慢。

相关标签:劣势

本文原创发布php中文网,转载请注明出处,感谢您的尊重!

MySQL级联优缺点_【Mysql】外键级联与级联的劣势_MySQL相关推荐

  1. mysql级联删除外键约束_玩转MySQL的外键约束之级联删除篇

    [IT168 文档]如今,许多关系型数据库管理系统都提供了外键约束这一强大的功能特性,它能够帮助我们自动地触发指定的动作,诸如删掉.更新数据库表的记录等,从而维护各数据库表之间预定义的关系.本文将演示 ...

  2. mysql级联删除外键约束_MySQL外键约束、级联更新、级联删除

    MySQL支持外键(foreign key),外键允许跨表交叉引用相关数据,另外外键约束能够保证相关数据的一致性.一个外键关系通常包括一个父表和一个子表.父表包含原始的字段数据,子表引用父表中该字段的 ...

  3. DBeaver mysql 外键设置了级联删除,子表无法添加数据

    DBeaver mysql 外键设置了级联删除,子表无法添加数据 报错:Cannot add or update a child row: a foreign key constraint fails ...

  4. mysql中为表增加外键_如何在Excel 2013中为符号分配键盘快捷键

    mysql中为表增加外键 We've previously shown you how to add keyboard shortcuts to symbols in Word 2013 to mak ...

  5. mysql创建表时设置外键_mysql创建表时设置外键约束的方法

    mysql创建表时设置外键约束的方法 发布时间:2020-06-17 15:54:11 来源:亿速云 阅读:312 作者:元一 MySQL是一种关系型数据库管理系统,关系数据库将数据保存在不同的表中, ...

  6. mysql修改外键字段报异常_mysql修改索引时,外键约束造成的奇怪问题_MySQL

    Mysql外键 bitsCN.com mysql修改索引时,外键约束造成的奇怪问题 事情是这样的,在Windows的mysql5.5 ,我想修改一个表的索引,于是执行 [sql] ALTER TABL ...

  7. MySQL级联优缺点_【Mysql】外键级联与级联的劣势

    在建表的时候时候,可以对于删除delete.修改update设置为级联.用一个例子先说明外键级联级联的概念 假如数据库中本以存在一张usertable如下: 此user表非常简单,id为主键. 下面我 ...

  8. mysql级联删除外键约束_MySQL外键约束,级联删除

    如果您的级联删除一个产品,因为它是一个类别的成员被杀死,那么你设置你的外键不当.给定示例表,您应该设置了以下表:CREATE TABLE categories ( id int unsigned no ...

  9. MySQL 外键约束 以及 级联操作

    外键约束 --- 将一个列添加外键约束与另一张表的主键(唯一键)进行关联之后,这个外键约束的 列 添加的数据 必须要在 关联的 主键字段 中存在 方案 1 : 1.首先先创建没有关系的班级表 2.再创 ...

最新文章

  1. Mybatis底层原理学习(二):从源码角度分析一次查询操作过程
  2. 命令行下载利器- Aria2
  3. Fiori应用里如何给客户主数据维护图片
  4. html界面等待状态,html 等待界面
  5. Adobe AIR * 设置移动应用程序属性
  6. LintCode2016年8月8日算法比赛----子树
  7. 疯狂Java讲义(十一)---- 初始化块
  8. 查看U盘是USB2.0还是USB3.0
  9. 黑马程序员_JavaWeb013
  10. 怎么设置电脑的固定IP地址?
  11. python实验报告代写_programs作业代写、代做data课程作业、代写Python实验作业、Python编程设计作业调试...
  12. 基于无线网络的环境监测系统
  13. 【企业开源】小米开源:站在巨人肩膀上的创新
  14. scuctf赛后自闭
  15. fastposter v2.7.0 发布 电商海报编辑器
  16. 以太坊五周年:从涅槃中苏醒
  17. Golang学习日志 ━━ gin-vue-admin实现多数据库db-list
  18. libreCAD源码阅读笔记4
  19. 《笨方法学python》习题43分析
  20. Android 原生分享文件到微信

热门文章

  1. idea项目中有jar包,java文件却引不进来
  2. 手机屏和大屏LCD显示面板接口(和处理器连接的接口类似12864等单片机处理器和屏接口的8086,SPI等并口串口屏以及RGB屏接口)LVDS接口常见于液晶电视中。eDP,LVDS,MIPI,HDMI
  3. Python Web开发——Django框架学习
  4. Python 包(package)
  5. C++ openCV 图像的读取、显示、保存、加权融合、改变对比度、修改色域
  6. OSError: cannot load library ‘C:\...\site-packages\_soundfile_data\libsndfile64bit.dll‘: error 0x7e
  7. 面试结束后,公司为什么不直接告诉我结果,而是让我回去等消息?
  8. 记住下次看小电影前一定要检查域名是不是 HTTPS 的!
  9. 我的世界粘土服务器的虚拟键盘,我的世界boat全键盘版
  10. 微信小程序dom limit无法渲染更多节点问题