MySQL触发器

一、触发器简介

1、触发器简介

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

2、触发器的优点

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

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

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

D、实现复杂的非标准的数据库相关完整性规则。
触发器可以对数据库中相关的表进行连环更新。
  在修改或删除时级联修改或删除其它表中的与之匹配的行。
  在修改或删除时把其它表中的与之匹配的行设成NULL值。
在修改或删除时把其它表中的与之匹配的行级联设成缺省值。
  触发器能够拒绝或回退那些破坏相关完整性的变化,取消试图进行数据更新的事务。
E、同步实时地复制表中的数据。
F、SQL触发器提供了运行计划任务的另一种方法。
自动计算数据值,如果数据的值达到了一定的要求,则进行特定的处理。例如,如果公司的帐号上的资金低于5万元则立即给财务人员发送警告数据。

3、触发器的限制

A、触发程序不能调用将数据返回客户端的存储程序,也不能使用采用CALL语句的动态SQL语句,但是允许存储程序通过参数将数据返回触发程序,也就是存储过程或者函数通过OUT或者INOUT类型的参数将数据返回触发器是可以的,但是不能调用直接返回数据的过程。
B、不能在触发器中使用以显示或隐式方式开始或结束事务的语句,如START TRANS-ACTION,COMMIT或ROLLBACK。

二、触发器的使用

1、创建触发器

创建触发器的语法:

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包含的多条语句。
  • FOR EACH ROW表示任何一条记录上的操作满足触发事件都会触发该触发器。

MySQL除了对INSERT、UPDATE、DELETE基本操作进行定义外,还定义了LOAD DATA和REPLACE语句,这两种语句也能引起上述6中类型的触发器的触发。

  • LOAD DATA 语句用于将一个文件装入到一个数据表中,相当与一系列的 INSERT操作。
  • REPLACE语句一般来说和INSERT语句很像,只是在表中有primary key或 unique索引时,如果插入的数据和原来 * primary key或unique索引一致时,会先删除原来的数据,然后增加一条新数据。
  • INSERT型触发器:插入某一行时激活触发器,通过 INSERT、LOAD DATA、REPLACE语句触发;
  • UPDATE型触发器:更改某一行时激活触发器,通过UPDATE语句触发;
  • DELETE型触发器:删除某一行时激活触发器,通过DELETE、REPLACE语句触发。

MySQL中定义了NEW和OLD,用来表示触发器的所在表中,触发了触发器的那一行数据。
在INSERT型触发器中,NEW用来表示将要(BEFORE)或已经(AFTER)插入的新数据;
在UPDATE型触发器中,OLD用来表示将要或已经被修改的原数据,NEW用来表示将要或已经修改为的新数据;
在DELETE型触发器中,OLD用来表示将要或已经被删除的原数据;

使用方法:NEW.columnName(columnName为相应数据表某一列名)
另外,OLD是只读的,而NEW则可以在触发器中使用SET赋值,不会再次触发触发器,造成循环调用。

2、删除触发器

DROP TRIGGER [IF EXISTS] [schema_name.]trigger_name
schema_name是数据库的名称,是可选的。如果省略了schema,将从当前数据库中舍弃触发程序。
trigger_name是要删除的触发器的名称。

3、触发器信息查看

在MySQL中,所有的触发器的定义都存在于INFORMATION_SCHEMA数据库的triggers表中,可以通过查询命令SELECT来查看,具体语法如下:
SHOW TRIGGERS [FROM schema_name];
图片
触发器的执行顺序
InnoDB数据库,若SQL语句或触发器执行失败,MySQL会回滚事务,有:

  • A、如果BEFORE触发器执行失败,SQL无法正确执行。
  • B、SQL执行失败时,AFTER型触发器不会触发。
  • C、AFTER类型的触发器执行失败,SQL会回滚。
    MySQL的触发器是按照BEFORE触发器、行操作、AFTER触发器的顺序执行的,其中任何一步发生错误都不会继续执行剩下的操作,如果对事务表进行的操作,如果出现错误,那么将会被回滚,如果对非事务表进行操作,那么就无法回滚,数据可能会出错。

    三、触发器应用

    只取两个方面的应用来讲:数据备份、运行计划任务

    1、数据备份

    每当删除一个数据时,利用触发器及时备份旧数据

    DROP TABLE IF EXISTS dump_classes;
    CREATE TABLE dump_classes(
      id INT(10) UNSIGNED AUTO_INCREMENT PRIMARY KEY,
        class_id INT(10) NOT NULL DEFAULT 0,
        class_name VARCHAR(16) NOT NULL DEFAULT ''
    );
    DROP TRIGGER IF EXISTS dump_classes;
    CREATE TRIGGER dump_classes AFTER DELETE ON classes FOR EACH ROW
    BEGIN
       INSERT INTO dump_classes_del(class_id,class_name) VALUES(old.class_id,old.class_name);
    END;
    CREATE TRIGGER dump_classes_upd AFTER UPDATE ON classes FOR EACH ROW
    BEGIN
       INSERT INTO dump_classes(class_id,class_name) VALUES(old.class_id,old.class_name);
    END;

    测试结果
    图片
    图片

    2、运行计划任务

    当有学生考试不及格时,触发一个触发器,该触发器调用系统中的告警脚本,例子暂时略,因为自己没用过mysql触发器调用外部程序。