赞
踩
触发器是与表有关的数据库对象,指在insert/update/delete之前或之后,触发并执行触发器中定义的sql语句集合。触发器可以协助应用在数据库端确保数据的完整性,日志记录,数据校验等操作。使用别名OLD和NEW来引用触发器中发生变化的记录内容,这与其他的数据库是相似的。现在触发器还只支持行级触发,不支持语级触发。
触发器类型 | new和old |
---|---|
insert型触发器 | new 表示将要或者已经新增的数据 |
update型触发器 | old表示修改之前的数据,new表示将要或已经修改后的数据 |
delete型触发器 | old表示将要活着已经删除的数据 |
create trigger trigger_name
before/after insert/update/delete
on table_name for each row --行级触发器
begin
trigger_stmt;
end
show triggers;
drop trigger [schema_name.]trigger_name; --如果没有指定shcema_name,默认为当前数据库
通过触发器记录某个表的数据变更日志,将变更日志插入到日志表user_logs中,包含增加,修改和删除;
创建日志表
create table user_logs(
id int(11) not null auto_increment,
operation varchar(20) not null,
operate_time datetime not null,
operate_id int(11) not null,
operate_param varchar(500),
primary key(id)
)engine=innodb default charset=utf8;
创建触发器
create trigger tb_user_insert_trigger
after insert on 用户表 for each row
begin
insert into user_logs(id,operation,operate_time,operate_id,operate_param) values
(null ,'insert',now(),new.用户ID,concat('插入数据的内容为:用户ID=',new.用户ID,'姓名=',new.姓名,'年龄=',new.年龄));
end;
查看触发器
show triggers;
触发触发器
insert into 用户表(姓名,年龄) values('nihao',23);
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。