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触发器基于行触发的特性,因此对于批量操作并不适合使用触发器
  • 使用触发器实现的业务逻辑在出现问题时很难进行定位,特别是设计到多个触发器的情况
  • 协同开发时,写业务层代码如果不清楚数据库触发器的细节,容易搞不清到底触发了那些触发器
  • 大量使用触发器会导致代码结构容易被打乱,阅读源码困难
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 触发器是一种与表操作有关的数据库对象。当有触发器的数据表上出现指定事件时,将调用该触发器对象,即表上的操作事件触发...
    西瓜很甜哟阅读 6,842评论 0 23
  • MySQL包含对触发器的支持。触发器是一种与表操作有关的数据库对象,当触发器所在表上出现指定事件时,将调用该对象,...
    金星show阅读 4,243评论 0 3
  • 借助脚蹬和车轮 在阳光里游向时间的入口 满街十五六岁的鲜花 喧闹着陌生的语言 以最快的速度游过 熟悉的树阴和里面的...
    忆荆高阅读 1,313评论 0 0
  • 我在想 我们会平平凡凡地度过此生吗 我们的人生会不会有所不同 如果可以精彩为什么不是现在 为什么要让...
    余七泽阅读 2,383评论 6 4
  • 文/Meetingtian 提起明清的晋商文化,大家跃然眼前的一定是乔家大院,平遥古城等等,但是在山西省太谷县的一...
    MeetingTian阅读 5,319评论 44 18