触发器

来源:互联网 发布:台球厅计时软件 编辑:程序博客网 时间:2024/06/11 06:15

触发器



BEFORE 之前 AFTER 之后


1.在person表中创建触发器t1,当向person表中插入一条记录时触发.
  触发执行动作为:更新number表中count字段值加一
  
mysql> DELIMITER //
mysql> CREATE TRIGGER t1
    -> AFTER
    -> INSERT ON person
    -> FOR EACH ROW
    -> BEGIN
    -> declare c int;
    -> set c=(SELECT count FROM number);
    -> UPDATE number set count=c+1;
    -> END
    -> //

2.在person表中创建触发器t2,当向person表中删除一条记录时触发.
  触发执行动作为:更新number表中count字段值减一
  
mysql> DELIMITER //
mysql> CREATE TRIGGER t2
    -> AFTER DELETE ON person
    -> FOR EACH ROW
    -> BEGIN
    -> declare c int;
    -> set c = (select count from number);
    -> UPDATE number SET count=c-1;
    -> END
    -> //

3.查看触发器
和查看数据库(show databases;)查看表格(show tables;)一样,查看触发器的语法如下:
SHOW TRIGGERS [FROM schema_name];
SHOW TRIGGERS [FROM schema_name] \G; //格式化输出


示例:
SHOW TRIGGERS \G;    //格式化显示当前数据库所有触发器


4.删除触发器
和删除数据库、删除表格一样,删除触发器的语法如下:
DROP TRIGGER [IF EXISTS] [schema_name.]trigger_name


示例:
DROP TRIGGER IF EXISTS t1;   //删除触发器t1




2.NEW 与 OLD 详解
上述示例中使用了NEW关键字,和 MS SQL Server 中的 INSERTED 和 DELETED 类似,MySQL 中定义了 NEW 和 OLD,用来表示
触发器的所在表中,触发了触发器的那一行数据。
具体地:
在 INSERT 型触发器中,NEW 用来表示将要(BEFORE)或已经(AFTER)插入的新数据;
在 UPDATE 型触发器中,OLD 用来表示将要或已经被修改的原数据,NEW 用来表示将要或已经修改为的新数据;
在 DELETE 型触发器中,OLD 用来表示将要或已经被删除的原数据;
使用方法: NEW.columnName (columnName 为相应数据表某一列名)
另外,OLD 是只读的,而 NEW 则可以在触发器中使用 SET 赋值,这样不会再次触发触发器,造成循环调用(如每插入一个学生前,都在其学号前加“2013”)。