MySQL触发器

介绍

触发器是与表有关的数据库对象,指在 insert/update/delete 之前或之后,触发并执行触发器中定义的SQL语句集合。触发器的这种特性可以协助应用在数据库端确保数据的完整性 , 日志记录 , 数据校验等操作 。
使用别名 OLD 和 NEW 来引用触发器中发生变化的记录内容,这与其他的数据库是相似的。现在触发器还只支持行级触发,不支持语句级触发。
在这里插入图片描述

创建触发器

语法结构 :

create trigger trigger_name
before/after insert/update/delete
on tbl_name
[ for each row ] -- 行级触发器
begin
    trigger_stmt;
end;

1)示例需求:

通过触发器记录 emp 表的数据变更日志 , 包含增加, 修改 , 删除 ;

2)首先创建操作表和日志表 :

create table emp_logs(
id int(11) not null auto_increment,
operation varchar(20) not null comment '操作类型, 
insert/update/delete',
operate_time datetime not null comment '操作时间',
operate_id int(11) not null comment '操作表的ID',
operate_params varchar(500) comment '操作参数',
primary key(`id`)
)engine=innodb default charset=utf8;

create table emp(
id int(11) not null auto_increment ,
name varchar(50) not null comment '姓名',
age int(11) comment '年龄',
salary int(11) comment '薪水',
primary key(`id`))engine=innodb default charset=utf8 ;

insert into emp(id,name,age,salary) values(null,'金毛狮王',55,3800),(null,'白眉鹰王',60,4000),(null,'青翼蝠王',38,2800),(null,'紫衫龙王',42,1800);

3)创建 insert 型触发器,完成插入数据时的日志记录 :(插入是new)

DELIMITER $
create trigger emp_logs_insert_trigger
after insert
on emp
for each row
begin
insert into emp_logs (id,operation,operate_time,operate_id,operate_params)
values(null,'insert',now(),new.id,concat('插入后(id:',new.id,', name:',new.name,',age:',new.age,', salary:',new.salary,')'));
end $
DELIMITER ;

验证:

insert into emp(id,name,age,salary) values(null,'谢逊',55,3800);

在这里插入图片描述
4)创建 update 型触发器,完成更新数据时的日志记录 :(更新旧的用old,新的用new)

DELIMITER $
create trigger emp_logs_update_trigger
after update
on emp
for each row
begin
    insert into emp_logs (id,operation,operate_time,operate_id,operate_params)
    values(null,'update',now(),new.id,concat('修改前(id:',old.id,', name:',old.name,',age:',old.age,', salary:',old.salary,') , 修改后(id',new.id, 'name:',new.name,',age:',new.age,', salary:',new.salary,')'));
end $
DELIMITER ;

验证:

update emp set age = 39 where id = 3;

5)创建delete 行的触发器 , 完成删除数据时的日志记录

DELIMITER $
create trigger emp_logs_delete_trigger
after delete
on emp
for each row
begin
    insert into emp_logs (id,operation,operate_time,operate_id,operate_params)
    values(null,'delete',now(),old.id,concat('删除前(id:',old.id,', name:',old.name,',age:',old.age,', salary:',old.salary,')'));
end $
DELIMITER ;

测试:

delete from emp where id = 5;

删除触发器

语法结构 :
如果没有指定 schema_name,默认为当前数据库 。

drop trigger [schema_name.]trigger_name
drop trigger emp_logs_delete_trigger;

查看触发器

可以通过执行 SHOW TRIGGERS 命令查看触发器的状态、语法等信息。
语法结构 :

show triggers \G;