MySQL触发器

触发器?

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触发器基于行触发的特性,因此对于批量操作并不适合使用触发器
  • 使用触发器实现的业务逻辑在出现问题时很难进行定位,特别是设计到多个触发器的情况
  • 协同开发时,写业务层代码如果不清楚数据库触发器的细节,容易搞不清到底触发了那些触发器
  • 大量使用触发器会导致代码结构容易被打乱,阅读源码困难

你可能感兴趣的:(MySQL触发器)