sqlupdate触发器_⾼级SQL之触发器
点击蓝字关注我吧
【本⽂详细介绍了数据库中触发器的基本概念和使⽤⽅法,欢迎读者朋友们阅读、转发和收藏!】
1 基本概念
1.1 触发器的概述
触发器其实是⼀种特殊的存储过程。⼀般的存储过程是通过存储过程名直接调⽤,⽽触发器主要是通过事件 ( 增、删、改 ) 进⾏触发⽽被执⾏的,在表中数据发⽣变化时⾃动强制执⾏。
常见的触发器有两种:after(for) 、 instead of, ⽤于 insert 、 update 、 delete 事件。
after(for) 表⽰执⾏代码后,执⾏触发器
instead of 表⽰执⾏代码前,⽤已经写好的触发器代替你的操作。
1.2 触发器的⽤法
创建触发器
语法如下
CREATE TRIGGER trigger_name trigger_time trigger_event
ON tbl_name FOR EACH ROW trigger_stmt
触发程序是与表有关的命名数据库对象,当表上出现特定事件时,将激活该对象。
触发程序与命名为 tbl_name 的表相关。tbl_name 必须引⽤永久性表。不能将触发程序与临时表或视图关联起来。
trigger_time 是触发程序的动作时间。它可以是 BEFORE 或 AFTER ,以指明触发程序是在激活它的语句之前或之后触发。
trigger_event 指明了激活触发程序的语句的类型。trigger_event 可以是下述值之⼀:
· INSERT :将新⾏插⼊表时激活触发程序,例如,通过 INSERT 、 LOAD DATA 和 REPLACE 语句。
· UPDATE :更改某⼀⾏时激活触发程序,例如,通过 UPDATE 语句。
·
DELETE :从表中删除某⼀⾏时激活触发程序,例如,通过 DELETE 和 REPLACE 语句。
请注意, trigger_event 与以表操作⽅式激活触发程序的 SQL 语句并不很类似,这点很重要。
例如,关于 INSERT 的 BEFORE 触发程序不仅能被 INSERT 语句激活,也能被 LOAD DATA 语句激活。
可能会造成混淆的例⼦之⼀是 INSERT INTO .. ON DUPLICATE UPDATE ... 语法:BEFORE INSERT 触发程序对于每⼀⾏将激活,后跟AFTER INSERT 触发程序,或 BEFORE UPDATE 和 AFTER UPDATE 触发程序,具体情况取决于⾏上是否有重复键。
对于具有相同触发程序动作时间和事件的给定表,不能有两个触发程序。
例如,对于某⼀表,不能有两个 BEFORE UPDATE 触发程序。
sql中update什么意思但可以有 1 个 BEFORE UPDATE 触发程序和 1 个 BEFORE INSERT 触发程序,或 1 个 BEFORE UPDATE 触发程序和 1 个 AFTER UPDATE 触发程序。
trigger_stmt 是当触发程序激活时执⾏的语句。
如果你打算执⾏多个语句,可使⽤ BEGIN ... END 复合语句结构。这样,就能使⽤存储⼦程序中允许的相同语句。
删除触发器
使⽤ DROP TRIGGER 语句可以删除 MYSQL 中已经定义的触发器。
我知道你在看哟
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论