触发器

时间:2021-07-16
本文章向大家介绍触发器,主要包括触发器使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。

--触发器:在增删改之前或之后,触发执行触发器中定义的sql语句集合,可用于保持数据完整性,日志记录,数据校验等操作,

触发器类型有new:插入或更新后的新数据,old:删改之前的数据
创建触发器:
create trigger trigger_name
before/after insert/delete/UPDATE
on table_name
[for each row] --行级触发器,mysql只有行级触发器,Oracle还有语句级触发器
begin
trigger_statement;
end;
--通过触发器记录test表的数据变更日志,包含增删改
--受限创建一张日志表
create table test_log(
id int(11) not null auto_increment,
operation varchar(20) not null comment '操作类型,insert/delete/update',
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 trigger test_insert_trigger
after insert
on test
for each row
begin
insert into test_log(id,operation,operate_time,operate_id,operate_params)values(null,'insert',now(),new.id,concat('id:',new.id,',name:',new.name));
end$

向test表中插入一条数据   insert into test value(null,'trigger')
查看日志表是否有触发器向里面插入数据select * from test_log

 --创建更新型触发器

create trigger test_update_trigger
after update
on test
for each row
begin
insert into test_log(id,operation,operate_time,operate_id,operate_params)values(null,'update',now(),new.id,concat('更新之前:','id:',old.id,',name:',old.name,'更新之后,id:',new.id,',name:',new.name));
end$

 查看触发器:

show triggers

删除触发器:

drop trigger trigger_name

原文地址:https://www.cnblogs.com/1--2/p/15020818.html