首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    MySQL外键约束On Update和On Delete的使用说明

    https://cloud.tencent.com/On Update和On Delete是SQL语言的一个标准,用于数据库外键定义,设置当主键表中的被参考列的数据发生变化时,外键表中响应字段的变换规则...On Update表示主键表中被参考字段的值被更新时,On Delete表示主键表中被参考字段的值被删除时。...有no action , set null , set default ,cascade四个选项,分别表示:1.no action 表示 不做任何操作,2.set null 表示在外键表中将相应字段设置为...null3.set default 表示设置为默认值4.cascade 表示级联操作,就是说,如果主键表中被参考字段更新,外键表中也更新,主键表中的记录被删除,外键表中改行也相应删除。...级联更新时,依据的是之前匹配的数据,在主表更新关联的外键字段的值后,系统自动更新从表的相应外键字段的值,而不是其他未设置为主外键关联的字段,不是主外键关联的字段不受影响。

    11710

    MySQL 学习笔记(三):完整性和触发器设计

    cascade on update cascade, foreign key (Cno) references Course(Cno) on delete cascade /*定义(Sno..... on delete cascade on update cascade, /*定义Cno为外键参考course表的主键Cno,并且实现级联删除SC表中相应的元组 */ );  2....外键约束 + 级联(删除/更新) alter table 从表 add constraint 约束名 foreign key(属性名) references 主表(属性名)  ON DELETE CASCADE...on delete cascade on update cascade; alter table SC add constraint SC_Courses foreign key(cno) references...这里我创建外键的时候 sno 中有些表有主键约束,有些却没有,所以当我删除主键约束的时候它会提示外键被错误建立起来了。但我不明白为什么建立外键的时候没有报错。

    1.5K40

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

    场景 我们用Django的Model时,有时候需要关联外键。关联外键时,参数:on_delete的几个配置选项到底是干嘛的呢,你知道吗? 参数介绍 models.CASCADE 级联删除。...比如:用户的有一个外键关联的是用户的健康记录表,当用户删除时,配置了这个参数的健康记录表中跟这个用户有关的数据也会被删除。...提醒:级联删除不会调用model级行为,但是会为所有已删除对象发送pre_delete和 post_delete信号,有用Django的信号机制的场景,要考虑这个级联删除带来影响。...models.SET_NULL 设置关联的外键内容为null。只有设置了null=True时可用。当数据被删除时,被关联的外键内容被设置为null。...models.SET_DEFAULT 将外键的值设置为默认值。外键必须设置有默认值 。 models.SET()将SET()设置的值作为外键的值 ,如果传递了callable,则调用它的结果。

    2K10

    POSTGRESQL 性能优化 数据的DML 需要进行优化吗? 当然

    实际上POSTGRESQL 的DML 只分为两类 1 INSERT 2 SELECT INSERT = UPDATE OR DELETE 数据插入和找到需要进行修改的数据,并在次将新的数据进行插入的操作...INDEX 的数量和质量问题 2 数据表中的FACTOR的状态和设置 3 UPDATE 的频率问题 4 Autovacuum 频率调整的问题 5 定期需要进行pg_repack 的工作 6 外键与约束的影响...2 Factor 因子,大部分数据表操作中都很少触及这个项目,但POSTGRESQL 在频繁的UPDATE 中尽量还是考虑这个问题,因为UPDATE = DELETE OLD + INSERT NEW...6 外键与约束,约束本身并不会对表的数据的插入产生过多的影响,而一些设计不好的外键并且带有级联性质的设计,才是对表DML操作带来性能问题的一个因素,减少外键级联的设计,有助于提高POSTGRESQL 的数据的...实际上除了这些,还有trigger的操作,如果 trigger 本身并不是频繁触发,并且里面并不带有大了的UPDATE 语句,那么trigger 还是可以被接受的,但如果trigger 本身里面就带有大了的

    91341

    MySQL实战七:你不知道的外键与约束使用!

    2.2 外键 2.2.1 创建外键 (1)不带别名的外键,数据库自动生成 首先创建department表: CREATE TABLE department ( dept_name varchar...学习 cascade 表示级联操作,就是说,如果主键表中被参考字段更新,外键表(子表)中也更新,主键表(父表)中的记录被删除,外键表(子表)中改行也相应删除。...CASCADE) 不管有没有on delete cascade都会出现这个问题。...上述on delete cascade换成on update cascade,可以发现只能更新父表的主键,同时父子表数据都会被更新,但是在子表的外键上做更新操作无效!...cascade 不能更新父表主键或子表外键,删除父表主键数据会将子表联同删除,删除子表外键数据不影响父表。

    4.3K20

    MySQL系列:(3)MySQL加强

    FROM T_Persons; -- 不能影响自增长约束 TRUNCATE TABLE T_Persons;-- 可以影响自增长约束 2.7、外键 作用:约束两种表的数据 语法:CONSTRAINT...外键名 FOREIGN KEY(副表的外键字段) REFERENCES 主表(主表的主键) -- 部门表(主表) CREATE TABLE T_Department( Id INT PRIMARY KEY...DELETE CASCADE 注意: 级联操作必须在外键基础上使用 CREATE TABLE T_Employee( Id INT PRIMARY KEY AUTO_INCREMENT, NAME... ON DELETE CASCADE ) 3、数据库三大范式和MySQL变量 3.1、三大范式 设计原则: 建议设计的表尽量遵守三大范式。...语法: DELIMITER $ CREATE TRIGGER 触发器的名字 AFTER INSERT/UPDATE/DELETE ON 表名 FOR EACH ROW BEGIN -- SQL语句 END

    74910

    MySQL触发器

    触发器的创建  创建触发器语法 CREATE TRIGGER 触发器名称 {BEFORE|AFTER} {INSERT|UPDATE|DELETE} ON 表名 FOR EACH ROW 触发器执行的语句块...INSERT | UPDATE | DELETE :表示触发的事件。 INSERT 表示插入记录时触发; UPDATE 表示更新记录时触发; DELETE 表示删除记录时触发。...注意点 注意,如果在子表中定义了外键约束,并且外键指定了ON UPDATE/DELETE CASCADE/SET NULL子句,此时修改父表被引用的键值或删除父表被引用的记录行时,也会引起子表的修改和删除操作...,此时基于子表的UPDATE和DELETE语句定义的触发器并不会被激活。...例如:基于子表员工表(t_employee)的DELETE语句定义了触发器t1,而子表的部门编号(did)字段定义了外键约束引用了父表部门表(t_department)的主键列部门编号(did),并且该外键加了

    3.2K20

    MySql数据库约束

    外键(Foreign Key)约束   c. 编写触发器   d....外键约束 外键用来保证参照完整性,MySQL数据库的MyIsAM存储引擎本身并不支持外键,对于外键的定义只是起到一个注释的作用,而InonoDB存储引擎则完整支持外键约束。...一般来说,称被引用的表为父表,引用的表称为子表,外键定义时的on delete和on update表示在对父表进行delete和updata操作时,对子表所做的操作。...可定义的子表操作有: (1)CASCADE    表示当父表发生delete和update操作时,对相应的子表中的数据页进行delete和update操作 (2)SET FULL   表示当父表发生delete...(4)RESTRICT   表示父表发生delete或update操作时,抛出错误,不允许这类操作发生,如果定义外键时没有指定on delete或on update,RESTRICT就是默认的外键设置

    1.2K10
    领券