您好,欢迎访问一九零五行业门户网

数据库基础<四)触发器

1、概念 触发器(trigger)是用户定义在关系表上的一类由事件驱动的特殊过程,一旦定义,任何用户 对表的增、删、改操作均由服务器自动激活相应的触发器,在dbms核心层进行集中的完整性控制。 2、定义触发器 create trigger 触发器名 before|after 触发事件
1、概念触发器(trigger)是用户定义在关系表上的一类由事件驱动的特殊过程,一旦定义,任何用户
对表的增、删、改操作均由服务器自动激活相应的触发器,在dbms核心层进行集中的完整性控制。
2、定义触发器create trigger before|after on
for each row|statement [when ]
触发事件:可以是 insert、delete 或 update ,可以是几个事件的组合,用or连接
update 后面还可以有 of
触发器类型:分为 for each row(行级触发器)和 for each statement(语句级触发器,触发一次)
触发动作体:可以是一个过程块或是对已创建存储过程的调用,如果是行级触发器,可以在过程体中
使用 new 和 old 引用 update/insert 事件之后的新值和 update/delete 事件之前的旧值
3、激活触发器同一个表上的多个触发器激活时的执行顺序:
1)执行该表上的 before 触发器
2)激活触发器的 sql 语句
3)执行该表上的 after 触发器
查看触发器是否被激活:show triggers 
4、删除触发器drop trigger on
5、mysql 触发器实例 create table test1(a1 int);create table test2(a2 int);create table test3(a3 int not null auto_increment primary key);create table test4( a4 int not null auto_increment primary key, b4 int default 0); delimiter | /* 改变输入结束符 */ create trigger testref before insert on test1 for each row begin insert into test2 set a2 = new.a1; delete from test3 where a3 = new.a1; update test4 set b4 = b4 + 1 where a4 = new.a1; end| delimiter ; insert into test3 (a3) values (null), (null), (null), (null), (null), (null), (null), (null), (null), (null); insert into test4 (a4) values (0), (0), (0), (0), (0), (0), (0), (0), (0), (0);如果将下述值插入表test1,如下所示:mysql> insert into test1 values -> (1), (3), (1), (7), (1), (8), (4), (4);query ok, 8 rows affected (0.01 sec)records: 8 duplicates: 0 warnings: 0那么4个表中的数据如下:mysql> select * from test1;+------+| a1 |+------+| 1 || 3 || 1 || 7 || 1 || 8 || 4 || 4 |+------+8 rows in set (0.00 sec) mysql> select * from test2;+------+| a2 |+------+| 1 || 3 || 1 || 7 || 1 || 8 || 4 || 4 |+------+8 rows in set (0.00 sec) mysql> select * from test3;+----+| a3 |+----+| 2 || 5 || 6 || 9 || 10 |+----+5 rows in set (0.00 sec) mysql> select * from test4;+----+------+| a4 | b4 |+----+------+| 1 | 3 || 2 | 0 || 3 | 1 || 4 | 2 || 5 | 0 || 6 | 0 || 7 | 1 || 8 | 1 || 9 | 0 || 10 | 0 |+----+------+10 rows in set (0.00 sec)
其它类似信息

推荐信息