mysql触发器级联更新_SQL触发器删除级联记录实现方法

本文介绍了在MySQL中如何使用触发器来实现级联删除,即当删除某个记录时,能够同时删除相关联的其他记录。通过创建`AFTER`触发器和`INSTEAD OF`触发器的示例,详细解释了它们的区别和使用场景,特别是在处理外键约束时的作用。同时提到了`deleted`表在触发器中的作用,它存储了被删除记录的副本。
摘要由CSDN通过智能技术生成

SQL触发器:当改变(增、删、改)数据表的记录时,绑定在SQL语句(增、删、改)中的触发器能够触发某些事件或者函数,所以我们可以在触发器中编写一些处理语句。

比如,当我们删除新闻类别的时候,由于外键的原因,我们无法删除新闻类别下有新闻内容的记录,但是通过,我们就可以实现。

代码如下

复制代码

delete from category where id=5 --sql删除语句

create trigger trigcategorydelete --当执行sql删除语句时,执行触发器

on category

after delete

as

begin

delete news where caId=( id from deleted) --删除对应新闻类别的新闻内容

end

照一般的思维,这样就可以同时删除新闻类别和其下的新闻内容,但是这样执行却不成功。是因为关键字AFTER,AFTER表示在执行SQL删除语句后,再执行触发器里的语句。这样一来,顺序同样是先删除新闻再删除新闻内容,肯定不成功。

改变关键字after为instead of

instead of,表示代替delete操作,而没有真正delete from category where id=5,当category表的删除时,同时触发了trigcategorydelete触发器,但是由于有instead of关键字,所以本身并不执行删除操作,而是执行触发器里的sql语句,从而可以替代之前的SQL语句。比如:

代码如下

复制代码

create trigger trigcategorydelete

on category

instead of delete

as

begin

declare @id int --定义一个变量id

select @id=id from deleted --从deleted临时表中,赋值id给变量@id

delete news where caId=@id --先删除该类别下的所有新闻

delete category where id=@id --然后删除新闻类别

end

当我们执行 delete from category where id=5时,id=5的类别并没有真正删除,而是转而执行触发器里面的SQL语句

关于deleted表:

Deleted表用于存储 DELETE 和 UPDATE 语句所影响的行的复本。在执行 DELETE 或 UPDATE语句时,行从触发器表中删除,并传输到deleted表中。Deleted表和触发器表通常没有相同的行。(//最后一句不是怎么明白啊?) by google

删除一条记录时候,他会把删除的这条记录放在一张临时表里,当你对category表进行删除时,在SQL返回的结果消息里面会提示出你删除的记录

f68f2add0b68e4f9810432fce46917b7.png

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值