触发器?
Mysql触发器是一种与表操作有关的数据库对象,当触发器所在表上出现指定事件时,将调用该对象,即表的操作事件触发表上的触发器的执行,与存储过程不一样,触发器是自动调用
一个简单的触发器
create trigger tri_stuInsert after insert
on student for each row
begin
declare c int;
set c = (select stuCount from class where classID=new.classID);
update class set stuCount = c + 1 where classID = new.classID;
end;
- 上面这个触发器的功能是在student表执行插入功能之后修改class 表的对应classID的stuCount
- for each row表示任何一条记录上的操作满足触发事件都会触发该触发器
- declare变量声明区
- before为触发时机,取值为 before(之前)或 after(之后)
- insert型触发器:插入某一行时激活触发器,可能通过 insert、load data、replace语句触发
- update型触发器:更改某一行时激活触发器,可能通过 update语句触发
- delete型触发器:删除某一行时激活触发器,可能通过 delete、replace语句触发
- 不能同时在一个表上建立2个相同类型的触发器,因此在一个表上最多建立6个触发器
- 在 insert型触发器中,new用来表示将要(before)或已经(after)插入的新数据;
- 在 update型触发器中,old 用来表示将要或已经被修改的原数据,new用来表示将要或已经修改为的新数据;
- 在 delete型触发器中,old用来表示将要或已经被删除的原数据;
- 使用方法: new.columnName (columnName 为相应数据表某一列名)
注
- 如果 before触发器执行失败,sql无法正确执行。
- sql执行失败时,after 型触发器不会触发。
- after类型的触发器执行失败,sql会回滚
弊端
- MySQL触发器能基于行触发,MySQL触发器始终时基于表中的一条记录触发,而不是一组SQL语句。因此,如果需要变动整个数据集而数据集数据量又较大时,触发器效果会非常低。
- 每一个表的一个事件只能定义一个触发器。
- 由于MySQL触发器基于行触发的特性,因此对于批量操作并不适合使用触发器
- 使用触发器实现的业务逻辑在出现问题时很难进行定位,特别是设计到多个触发器的情况
- 协同开发时,写业务层代码如果不清楚数据库触发器的细节,容易搞不清到底触发了那些触发器
- 大量使用触发器会导致代码结构容易被打乱,阅读源码困难