当前位置:   article > 正文

Mysql触发器_mysql触发器old和new

mysql触发器old和new

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 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 查看触发器
show triggers;
  • 1
  • 删除触发器
drop trigger [schema_name.]trigger_name; --如果没有指定shcema_name,默认为当前数据库
  • 1
  • 案例

通过触发器记录某个表的数据变更日志,将变更日志插入到日志表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;
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8

创建触发器

 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;
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6

查看触发器

show triggers;
  • 1

在这里插入图片描述
触发触发器

insert into 用户表(姓名,年龄) values('nihao',23);
  • 1

在这里插入图片描述

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/weixin_40725706/article/detail/601985
推荐阅读
相关标签
  

闽ICP备14008679号