大佬们一直说不要用触发器,触发器对性能影响很多,但是一直似懂非懂,借着最近有时间准备清理下公司库里的触发器,研究下触发器的机制跟对性能影响。
想来定义:
在MySQL中,触发器可以在你执行INSERT、UPDATE或DELETE的时候,执行一些特定的操作。在创建触发器时,可以指定是在执行SQL语句之前或是之后执行这些操作。通过触发器,你可以实现一些业务逻辑或一些数据限制,在简化应用程序逻辑,优化系统性能时非常有用。但在使用MySQL触发器也有一些注意事项,否则会导致触发器不能工作或不按指定的方式工作。
1. MySQL触发器注意事项
MySQL触发器使用非常简单,当然其功能也比较有限。当你在项目中大量使用触发器,那么你应该注意以下几点,以避免触发器不按预期效果执行:
- MySQL触发器能
基于行触发
,MySQL触发器始终时基于表中的一条记录触发,而不是一组SQL语句。因此,如果需要变动整个数据集而数据集数据量又较大时,触发器效果会非常低。 - 每一个表的一个事件只能定义一个触发器,例如:不能在
AFTER INSERT
上定义一个以上的触发器。
2. MySQL触发器可能导致的问题
由于MySQL触发器基于行触发
的特性,因此对于批量操作并不适合使用触发器,如:汇总表、缓存表等。触发器使用不当,可能会导致以下问题:
- 一个MySQL触发器可能会关联到另外一张表或几张表的操作。因此,会导致数据库服务器负荷也会相应的增加一倍或几倍,如果出现因为触发器问题导致的性能问题,会很难定位问题位置和原因。
- 在基于锁的操作中,触发器可能会导致锁等待或死锁。触发器执行失败,原来执行的SQL语名也会执行失败。而因为触发器导致的失败结果和失败原因,往往很难排查。
由于MySQL触发器的种种问题,要求我们在创建触发器就应该充分考虑。避免使用不合适的触发器,并能对所有触发器有足够的了解,以便问题的定位和排查。
3. MySQL触发器的好处
对MySQL触发器有足够的认识和了解后,MySQL触发器会给我们带来极大的便利。当实现一些系统约束时,或在实现系统维护及针对操作数据的更新时,使用触发器都非常方便。在之胶我们介绍了MySQL触发器不适合做的一些工作,但MySQL触发器在以下一些应用场景中,会非常实用:
- 基于行数据变更的日志记录。如:在用户订单系统中,我们可以基于用户订单数据状态的改变,使用触发器构建用户订单日志表数据。
- 基于行数据变更的关系数据的更新。如:用户订单改变至付款或相关状态时,我们可以基于用户订单数据状态的改变,使用触发器改变用户会付款或相应状态信息。
- 基于行数据变更的数据汇总。如:用户订单成交或失败,我们可以基于用户订单数据状态的改变,使用触发器构建用户总成交量或失败量汇总数据。
以上仅列举了一些常用场景,合理的利用MySQL触发器会在数据库工作效率和开发效率上有很大的提高。关于触发器的使用方法,请参考:MySql触发器trigger的使用