一、什么是触发器:
1、触发器是由事件来触发某个操作,这些事件包括insert、update和delete语句。
2、触发器实际是个特殊的存储过程,如果定义了触发程序,当数据库执行这些语句的时候就会激发触发器执行相应的操作;
触发程序是与表有关的命名数据库对象,当表上出现特定事件时,将激活该对象。
3、触发器可以查询其他表,而且可以包含复杂的SQL语句。主要用于满足复杂的业务规则或要求。
二、创建触发器:
1.语法:
create trigger trigger_name trigger_time trigger_event on table_name for each row
trigger_statement;
(1)trigger_name:触发器名称
(2)trigger_time:触发时机,before或after
before:先完成触发,再增删改,触发的语句先用于监视的增删改,我们就有机会判断、修改即将发生的操作。
after:先完成数据的增删改,再触发,触发的语句晚于监视的增删改操作,无法影响前面的增删改动作。
(3)trigger_event:触发事件,包括insert、update、delete
(4)table_name:表名,即在哪张表上建立触发器
(5)trigger_statement:触发器的程序体,对于多行语句,可以使用begin和end作为开始和结束。
在MySQL触发器中的SQL语句可以关联表中的任意列。但不能直接使用列的名称去标志,那会使系统混淆,因为激活触发器的语句可能已经修改、删除或添加了新的列名,而列的旧名同时存在。
因此必须用这样的语法来标志:“NEW.column_name”或者“OLD.column_name”。
NEW.column_name用来引用新行的一列;
OLD.column_name用来引用更新或删除它之前的已有行的一列。
对于INSERT语句,只有NEW是合法的;
对于DELETE语句,只有OLD才合法;而UPDATE语句可以与NEW或OLD同时使用。
注意事项:
不能在一个表内创建两个(包含两个)以上trigger_time和 trigger_event相同的触发器。