高级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 触发程序。

但可以有 1 个 BEFORE UPDATE 触发程序和 1 个 BEFORE INSERT 触发程序,或 1 个 BEFORE UPDATE 触发程序和 1 个 AFTER UPDATE 触发程序。

trigger_stmt 是当触发程序激活时执行的语句。

如果你打算执行多个语句,可使用 BEGIN ... END 复合语句结构。这样,就能使用存储子程序中允许的相同语句。

删除触发器

使用 DROP TRIGGER 语句可以删除 MYSQL 中已经定义的触发器。

我知道你在看

  • 发表于:
  • 原文链接https://kuaibao.qq.com/s/20200614A000B600?refer=cp_1026
  • 腾讯「云+社区」是腾讯内容开放平台帐号(企鹅号)传播渠道之一,根据《腾讯内容开放平台服务协议》转载发布内容。
  • 如有侵权,请联系 yunjia_community@tencent.com 删除。

扫码关注云+社区

领取腾讯云代金券