首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

【MySQL】外键约束的删除和更新总结

外键约束的删除/更新行为 行为 说明 NO ACTION 当在父表中删除/更新对应记录时,首先检查该记录是否有对应外键,如果有则不允许删除/更新。...(与RESTRICT一致) RESTRICT 当在父表中删除/更新对应记录时,首先检查该记录是否有对应外键,如果有则不允许删除/更新。...(与NOT ACTION一致) CASCADE 当在父表中删除/更新对应记录时,首先检查该记录是否有对应外键,如果有,则也删除/更新外键在子表总的记录。...SET NULL 当在父表中删除对应记录时,首先检查该记录是否有对应外键,如果有则设置该子表中该外键值为null(这就要求该外键允许取null)。...id改为6,emp表中的id也会跟着改变 当我们删除父表中id为6,我们可以看到子表emp中存在外键关联的数据也会被删除。

63010
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    django模型中有外键关系的表删除相关设置

    0904自我总结 django模型中有外键关系的表删除相关设置 一.一对一 例如有Author、AuthorDetail两表 author = models.OneToOneField(to='Author...作者删除详情删除,详情删除作者保留 2)作者找详情用 外键related_name(detail),详情找作者用 外键字段(author) 3)db_constraint断开表关联,on_delete...多的一方):出版社删除书外键不动,书删除没有任何影响 2)出版社找书用 外键related_name(books),书找出版社 外键字段(publish) 3)db_constraint断开表关联,...两者区别 models.SET关联表内容删了,关联的相关内容不会删除 models.CASCAD关联表内容删了,关联的相关内容会删除 db_constraint关系断开后,但是不影响联表查询 四.多对多关系...,但关系表一定级联删除 2)正向找 外键字段,反向找 外键字段related_name 3)db_constraint断开表关联,on_delete不存在(不设置,本质在第三张表中设置,且一定是级联

    3K20

    删除数据库中未指定名称的外键的存储过程

    数据库中的某个表A,因为业务原因被移到别的库。麻烦的是,有几张子表(B, C, D等)建有指向它的外键,而且在创建时没有指定统一的外键名。...如此一来,在不同的环境(开发、测试、生产等)中该外键的名称不一样,必须逐个去查询外键名再进行删除,十分不便。...Oracle的存储过程代码如下: -- 删除指定表、指定列上的外键(系统命名或未知名) CREATE OR REPLACE PROCEDURE DROP_FK(P_TABLE IN VARCHAR2,...: -- 删除指定表、指定列上的外键(系统命名或未知名) CREATE OR REPLACE FUNCTION DROP_FK(P_TABLE IN VARCHAR, P_COLUMN IN VARCHAR...: DELIMITER // DROP PROCEDURE IF EXISTS drop_fk// -- 删除指定表、指定列上的外键(系统命名或未知名) CREATE PROCEDURE drop_fk

    1.3K10

    删除mac启动台launchpad中的无效图标

    第一种情况 在Mac上安装Photoshop CS6的后, 启动台(LaunchPad)莫名其妙的多出了几个”Adobe xxxx…”的图标, 而且无法删除,在访达里面应用程序内也找不到, 非常讨厌。...在网上搜索了试过终端删除,app删除,找到程序文件夹删除等各种方法,但都失败了。。。 最后重点来了,我找到了一个终极解决办法: 重建 启动台(LaunchPad) 内的图标来解决....最后,你会发现重置之后之前的所有设置都会丢失. 没有特殊情况不要使用哦. 以免丢失之前的排列方式与文件夹....方法如下: 卸载应用程序之后,一般其在启动台生成的文件夹是不会被删除的,不过这个文件夹里面是空的。如果执意要删除的话,可以从Finder(访达)里面入手。...具体操作为,打开访达,按下快捷键「commond」+「shift」+「H」,之后页面会自动跳转到用户的主页。打开「应用程序文件夹」,里面的都是launchpad的内容,找到你要删除的目标将其删除即可。

    18.2K30

    SEO工作中,经常使用的无效外链有哪些?

    11.jpg 那么,无效外链都有哪些呢? 接下来就一起详细的了解一下吧!...1、博客论坛签名、评论的链接 ①有很多seo人员喜欢在博客以及论坛中来发布外链,因为在博客和论坛中发布的文章可以带上锚文本,这样有利于提升网站关键词在搜索引擎中的排名,从而提升网站的整体排名。...,如果选择这样的平台来发外链,那么,这个就是无效外链。...但在分类信息网中含有大量的网站链接,能够传递到网站的权重也可以说寥寥无几,并且有些分类信息网中也添加了nofollow标签,做这种外链只是在浪费时间,对网站优化没有任何帮助,还不如利用这个时间来写一篇高质量的原创文章呢...以上就是几种无效外链的方式。

    68520

    php中删除html标签和标签内内容的方法

    那要写很多需要保留的标签,所以有了第二个方法 2:删除指定的 html 标签 使用方法:strip_html_tags($tags,$str); $tags:需要删除的标签(数组格式) $str:...这里是 a 标签; 3:删除标签和标签的内容 使用方法:strip_html_tags($tags,$str); $tags:需要删除的标签(数组格式...4:终极函数,删除指定标签;删除或者保留标签内的内容; 使用方法:strip_html_tags($tags,$str,$content); $tags:需要删除的标签(数组格式) $str:需要处理的字符串...; $ontent:是否删除标签内的内容 0 保留内容 1 不保留内容 /** * 删除指定标签 * @param array $tags 删除的标签 数组形式 * @param string...沈唁志|一个PHPer的成长之路! 原创文章采用CC BY-NC-SA 4.0协议进行许可,转载请注明:转载自:php中删除html标签和标签内内容的方法

    5.4K30

    Django学习-第七讲:django 中的常用字段、字段属性,外键和表关系、外键操作

    外键和表关系 在MySQL中,表有两种引擎,一种是InnoDB,另外一种是myisam。如果使用的是InnoDB引擎,是支持外键约束的。外键的存在使得ORM框架在处理表关系的时候异常的强大。...第一个参数是引用的是哪个模型,第二个参数是在使用外键引用的模型数据被删除了,这个字段该如何处理,比如有CASCADE、SET_NULL等。这里以一个实际案例来说明。...那么在对方那个模型被删掉后,该进行什么样的操作。可以通过on_delete来指定。可以指定的类型如下: 1.CASCADE:级联操作。如果外键对应的那条数据被删除了,那么这条数据也会被删除。...即只要这条数据引用了外键的那条数据,那么就不能删除外键的那条数据。 3.SET_NULL:设置为空。如果外键的那条数据被删除了,那么在本条数据上就将这个字段设置为空。...如果外键的那条数据被删除了,那么本条数据上就将这个字段设置为默认值。如果设置这个选项,前提是要指定这个字段一个默认值。 5.SET():如果外键的那条数据被删除了。

    4K30

    WordPress中批量删除已发表文章中的多余DIV标签

    如果您需要在WordPress中批量删除已发表文章中的多余DIV标签,直接通过functions.php文件添加代码来自动删除这些标签可能不是最直接或最安全的方法,因为functions.php主要用于主题的功能扩展和定义...以下是一个示例查询,用于删除所有文章内容中的标签(请注意,这可能会影响到所有包含标签的文章,包括那些正确使用的):UPDATE wp_postsSET post_content =...考虑使用正则表达式:如果您的数据库支持正则表达式(如MySQL 8.0+中的REGEXP_REPLACE),您可以使用更精确的模式来匹配和删除多余的标签。...,从而安全地删除多余的标签。...内容备份发布WordPress中批量删除已发表文章中的多余DIV标签

    10910

    MySQL中创建外键的错误:1215 Cannot add the foreign key constraint

    引言: MySQL中经常会需要创建父子表之间的约束,这个约束是需要建立在主外键基础之上的,这里解决了一个在创建主外键约束过程中碰到的一个问题。 1....碰到错误 在创建外键之时,使用的SQL和碰到错误信息如下: alter table `product' add CONSTRAINT `sid_ref` FOREIGN KEY (`sid`)...REFERENCES `sealer` (`id`) ON DELETE NO ACTION ON UPDATE NO ACTION 碰到的错误信息如下: 无法正确的插入外键约束。...解决的办法 修改product.sid中的数据类型,添加unsigned和字段的长度,将其设置为相同即可。 5....总结 之所以出现1215的问题,是由于主外键之间的数据类型不一致造成的,以后类似问题,皆可按此处理。

    2.5K50

    Django 外键引用另一个表中的多个字段

    在 Django 中,外键(ForeignKey)通常只引用另一张表的一个字段,比如一个主键或一个唯一标识字段。然而,如果我们需要让一个外键引用另一张表中的多个字段,通常有以下几种方法来实现这种关系。...1、问题背景在 Django 中,模型之间的关系通常使用外键(ForeignKey)来建立。外键允许一个模型中的字段引用另一个模型中的主键。然而,有时我们需要在一个模型中引用另一个模型中的多个字段。...以下是如何在 Django 中使用复合主键来实现外键引用另一个表中的多个字段:在 product_models 模型中,添加一个 id 字段作为主键:class product_models(models.Model...添加一个 product 字段作为外键,并使用 MultipleFieldPrimaryKeys 选项来定义复合主键:class sales_process(models.Model):​ prospect...划重点Django 不直接支持复合外键,但可以通过添加唯一约束、使用中间表或在查询中使用逻辑约束来实现类似效果。

    10510

    【Django 2.2文档系列】Model 外键中的on_delete参数用法

    场景 我们用Django的Model时,有时候需要关联外键。关联外键时,参数:on_delete的几个配置选项到底是干嘛的呢,你知道吗? 参数介绍 models.CASCADE 级联删除。...Django会模拟SQL约束的行为,在删除此条数据时,同事删除外键关联的对象。...比如:用户的有一个外键关联的是用户的健康记录表,当用户删除时,配置了这个参数的健康记录表中跟这个用户有关的数据也会被删除。...” models.PROTECT 防止删除引用的对象。与上个恰恰相反,是防止关联数据被删除。 models.SET_NULL 设置关联的外键内容为null。只有设置了null=True时可用。...当数据被删除时,被关联的外键内容被设置为null。 models.SET_DEFAULT 将外键的值设置为默认值。外键必须设置有默认值 。

    2K10

    MySQL 外码约束原理:如何解决数据库添加数据时产生的外码(外键)约束?

    文章目录 前言 一、插入新数据时报错外键约束? 二、对于出错 SQL 语句的分析 三、对于外码约束的分析 四、如何处理外键约束?...本篇文章带你进一步来深度剖析,并带着你的思路来设计解决方案。 ---- 说明:本次案例的案例情景是传统的数据库表:学生-课程数据库。 一、插入新数据时报错外键约束?...我们在 Course 表中插入课程号为 1 的数据时提示违反了外键约束,插入命令如下: insert into course(cno,cname,cpno,ccredit) values('1','数据库...三、对于外码约束的分析 我们根据数据库定义的参照完整性规则得知:外键 cpno 的取值不为空的情况下(如上 cpno=‘5’),与其对应的主键 cno 在参照表中必须存在。...但是我们反观上面操作,第一个插入的就是 cno=‘1’ 的数据,cno=‘5’ 的还没有插入,很显然不满足参照完整性规则。 四、如何处理外键约束?

    3.2K20
    领券