MySQL触发器介绍及使用


1、触发器简介

触发器是一种特殊的存储过程, 它在插入, 删除或修改特定表中的数据时触发执行, 它比数据库本身标准的功能有更精细和更复杂的数据控制能力。

触发器是基于行触发的, 所以删除、 新增或者修改操作可能都会激活触发器, 不要编写过于复杂的触发器, 也不要增加过得的触发器, 这样会对数据的插入、 修改或者删除带来比较严重的影响, 同时也会带来可移植性差的后果, 所以在设计触发器的时候一定要有所考虑。


触发器作用

  • 安全性:可以基于数据库的值使用户具有操作数据库的某种权利
    可以基于时间限制用户的操作, 例如不允许下班后和节假日修改数据库数据。可以基于数据库中的数据限制用户的操作, 例如不允许股票的价格的升幅一次超过10%。

  • 审计:可以跟踪用户对数据库的操作
    审计用户操作数据库的语句。把用户对数据库的更新写入审计表。

  • 实现复杂的数据完整性规则
    实现非标准的数据完整性检查和约束。 触发器可产生比规则更为复杂的限制。 与规则不同, 触发器可以引用列或数据库对象。 例如, 触发器可回退任何企图吃进超过自己保证金的期货。
    提供可变的缺省值。

  • 实现复杂的非标准的数据库相关完整性规则
    触发器可以对数据库中相关的表进行连环更新。 例如, 在 auths 表 author_code 列上的删除触发器可导致相应删除在其它表中的与之匹配的行。
    在修改或删除时级联修改或删除其它表中的与之匹配的行。
    在修改或删除时把其它表中的与之匹配的行设成 NULL 值。
    在修改或删除时把其它表中的与之匹配的行级联设成缺省值。
    触发器能够拒绝或回退那些破坏相关完整性的变化, 取消试图进行数据更新的事务。 当插入一个与其主健不匹配的外部键时, 这种触发器会起作用。 例如, 可以在books.author_code 列上生成一个插入触发器,如果新值与 auths.author_code 列中的某值不匹配时, 插入被回退。

  • 同步实时地复制表中的数据。

  • 自动计算数据值, 如果数据的值达到了一定的要求, 则进行特定的处理。
    例如, 如果公司的帐号上的资金低于 5 万元则立即给财务人员发送警告数据。


2、查看触发器信息

1)查看语句

SELECT * FROM information_schema.triggers; #在 triggers 表中查看触发器信息

SHOW TRIGGERS #查看触发器信息


2)返回结果
在这里插入图片描述


3)指定触发器名称查询

所有触发器信息都存储在 information_schema 数据库下的 triggers 表中。可以使用 SELECT语句查询, 如果触发器信息过多, 最好通过 TRIGGER_NAME 字段指定查询:

SELECT * FROM information_schema.triggers WHERE TRIGGER_NAME='user_log';


3、创建触发器

1)语法

CREATE TRIGGER <触发器名> < BEFORE | AFTER >
<INSERT | UPDATE | DELETE >
ON <表名> FOR EACH Row<触发器主体>


2)参数说明

CREATE TRIGGER trigger_name trigger_time trigger_event ON tb_name
FOR EACH ROW trigger_stmt
  • trigger_name: 触发器的名称
  • tirgger_time: 触发时机, 为 BEFORE 或者 AFTER
  • trigger_event: 触发事件, 为 INSERT、 DELETE 或者 UPDATE
  • tb_name: 表示建立触发器的表明, 就是在哪张表上建立触发器
  • trigger_stmt: 触发器的程序体, 可以是一条 SQL 语句或者是用 BEGIN 和 END 包含的多条语句

MySQL 可以创建六种触发器:BEFORE INSERT, BEFORE DELETE, BEFORE UPDATE,AFTER INSERT, AFTER DELETE, AFTER UPDATE


3)实例

mysql> DELIMITER //
mysql> CREATE TRIGGER trigger_user BEFORE DELETE
-> ON `user` FOR EACH ROW
-> BEGIN
-> INSERT INTO logs VALUES(NOW());
-> END
-> //
Query OK, 0 rows affected (0.06 sec)

mysql> DELIMITER ;

注意: mysql 默认是以 ; 作为结束执行语句, 与触发器中需要的分行起冲突, 为解决此问题可用 DELIMITER, 如: DELIMITER //,可以将结束符号变成//。 当触发器创建完成后, 可以用 DELIMITER ;来将结束符号变成。


触发器名
触发器的名称, 触发器在当前数据库中必须具有唯一的名称。 如果要在某个特定数据库中创建, 名称前面应该加上数据库的名称。


INSERT | UPDATE | DELETE
触发事件, 用于指定激活触发器的语句的种类。

注意:三种触发器的执行时间如下:

  • INSERT: 将新行插入表时激活触发器。 例如, INSERT 的 BEFORE 触发器不仅能被 MySQL 的INSERT 语句激活, 也能被 LOAD DATA 语句激活。
  • DELETE: 从表中删除某一行数据时激活触发器, 例如 DELETE 和 REPLACE 语句。
  • UPDATE: 更改表中某一行数据时激活触发器, 例如 UPDATE 语句。


BEFORE | AFTER
BEFORE 和 AFTER, 触发器被触发的时刻, 表示触发器是在激活它的语句之前或之后触发。若希望验证新数据是否满足条件, 则使用 BEFORE 选项; 若希望在激活触发器的语句执行之后完成几个或更多的改变, 则通常使用 AFTER 选项。


表名
与触发器相关联的表名, 此表必须是永久性表, 不能将触发器与临时表或视图关联起来。 在该表上触发事件发生时才会激活触发器。同一个表不能拥有两个具有相同触发时刻和事件的触发器。 例如, 对于一张数据表, 不能同时有两个 BEFORE UPDATE 触发器, 但可以有一个BEFORE UPDATE 触发器和一个 BEFORE INSERT 触发器, 或一个 BEFORE UPDATE 触发器和一个 AFTER UPDATE 触发器。


触发器主体
触发器动作主体, 包含触发器激活时将要执行的 MySQL 语句。 如果要执行多个语句, 可使用 BEGIN…END 复合语句结构。


FOR EACH ROW
一般是指行级触发, 对于受触发事件影响的每一行都要激活触发器的动作。 例如, 使用INSERT 语句向某个表中插入多行数据时, 触发器会对每一行数据的插入都执行相应的触发器动作。


4、触发器类型

1)tigger_event触发事件
在这里插入图片描述


2)NEW 和 OLD 的使用
在这里插入图片描述
NEW.columnname: 新增行的某列数据
OLD.columnname: 删除行的某列数据


5、触发器的限制和注意事项

1)触发程序不能调用将数据返回客户端的存储程序, 也不能使用采用 CALL 语句的动态 SQL语句, 但是允许存储程序通过参数将数据返回触发程序, 也就是存储过程或者函数通过 OUT或者 INOUT 类型的参数将数据返回触发器是可以的, 但是不能调用直接返回数据的过程。


2)不 能 再 触 发 器 中 使 用 以 显 示 或 隐 式 方 式 开 始 或 结 束 事 务 的 语 句 , 如 START TRANS-ACTION,COMMIT 或 ROLLBACK。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值