【Mysql】外键级联与级联的劣势_MySQL
在建表的时候时候,可以对于删除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; -- 数据库引擎设置,可以没有
设置级联与不设置级联,在参照完整性上是没有区别的。
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语句在网页的编程的时间根本就是可以扔掉的。这样还有个好处,出现在需要找被删除的旧数据的时候,绝对可以找回来。
这样你的网页的运行速度会大大加快,否则如果一旦执行级联删除的语句,会涉及的表足够多的时候,执行起来将会足够慢。

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

热门话题

jQuery是一款广泛应用于前端开发的快速、小巧、功能丰富的JavaScript库。自2006年发布以来,jQuery已经成为众多开发者的首选工具之一,但是在实际应用中,它也不乏一些优势和劣势。本文将深度剖析jQuery的优势与劣势,并结合具体的代码示例进行说明。优势:1.简洁的语法jQuery的语法设计简洁明了,可以大大提高代码的可读性和编写效率。比如,

使用Serverless架构部署PHP应用程序具有以下优点:免维护、按需付费、高度可扩展、简化开发和支持多种服务。缺点包括:冷启动时间、调试困难、锁定供应商、功能限制和成本优化挑战。

vr的优势:1、沉浸式体验;2、交互性;3、多样性;4、安全性;5、便捷性。vr的劣势:1、技术门槛高;2、眩晕感;3、依赖性;4、隐私泄露风险;5、成本高昂。VR技术是一种先进的交互式技术,它通过模拟人的视听感知,创造一个完全虚拟的场景,使得用户可以在其中进行互动和体验。在未来的发展中,随着技术的不断进步和应用领域的不断拓展,VR技术将会得到更加广泛的应用和发展。

Go框架开发的优点包括:高效的性能、卓越的并发性、简单的语法、丰富的标准库、强类型语言和跨平台支持。缺点包括:缺乏泛型、新手经验不足、外部库依赖性、烦琐的错误处理和HTTP路由性能受限。

静态重定位技术是一种用于将软件或应用程序加载到内存中并分配内存地址的技术。它的目的是使程序可以在不同的环境中运行,无需修改源代码。然而,静态重定位技术也存在一些劣势。本文将探讨这些劣势,并提出一些改善方法。首先,静态重定位技术可能会导致内存碎片。当程序运行时,它会分配一块连续的内存空间来存储指令、数据和堆栈。然而,随着程序运行的时间增长,一些内存块可能会被释

在计算机编程领域,Go语言作为一种开发效率高、并发性能强的编程语言,受到了广泛的关注和应用。然而,正如任何一种编程语言一样,Go语言也存在着一些劣势,需要不断改进和优化。本文将深入探讨Go语言的劣势及改进方向,并结合具体的代码示例进行分析。一、劣势分析异常处理不够灵活在Go语言中,错误处理机制主要通过返回错误值来实现,这种机制虽然简单高效,但对于复杂的错误处

Go语言作为一种现代化的编程语言,具有简洁易学、并发性能强、内存管理高效、跨平台支持等优势。但是,它也存在生态系统相对较小、泛型支持不完善、错误处理方式有限、缺乏一些高级特性等劣势。开发人员在选择使用Go语言时,需要根据具体的应用场景和需求进行权衡和选择。

深入探讨Go编程语言的优势和劣势Go语言,也称为Golang,是一种开源编程语言,由谷歌开发。自2009年发布以来,Go语言在软件开发领域备受关注,被广泛应用于网络编程、云计算、大数据处理等多个领域。本文将深入探讨Go语言的优势和劣势,并通过具体的代码示例来说明。优势1.并发编程能力强Go语言内置goroutine和channel,使并发编程变得简单而高效
