Mysql触发器

文章目录

    • 1. 简介
    • 2. 触发器语法

1. 简介

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

触发器类型 new和old
insert型触发器 new 表示将要或者已经新增的数据
update型触发器 old表示修改之前的数据,new表示将要或已经修改后的数据
delete型触发器 old表示将要活着已经删除的数据

2. 触发器语法

  • 创建触发器
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);

Mysql触发器_第1张图片

你可能感兴趣的:(Mysql,mysql,数据库)