mysql触发器

1.什么是触发器

需求:出于审计目的,当有人在往temp_user 插入一条记录时,把插入的uid,uname,插入动作和操作时间记录下来。

delimiter $$
create trigger tr_user_insert after insert on temp_user
for each row
begin
  insert into temp_oplog(uid,uname,action,optime)
  values(new.uid,new.uname,'insert',NOW());
end;
$$
delimiter ;

1.创建触发器使用 create trigger 触发器名称

2.什么时候触发? after insert on temp_user,除了after还有before,是在对表操作之前(before)或之后(after)触发动作的。

3.对什么操作时事件触发? after insert on temp_user, 操作事件包括 insert,update,delete

4.对什么表触发? after insert on temp_user

5.影响的范围? for each row

6.NEW 代表 插入 更新 删除之后的字段值,OLD 代表插入 更新 删除之前的字段值

触发器:与函数、存储过程一样,触发器是一种对象,它能根据对表的操作事件,触发一些动作,这些动作可以是insert,update,delete等修改操作。

2.生产环境触发器实例

需求:出于审计目的,当删除users表时,记录删除前应该记录的主要字段值

create trigger tr_user_delete before delete on temp_user
for each row
BEGIN
  insert into temp_oplog(uid,uname,action,optime,old_value)
  values(OLD.uid,OLD.uname,'delete',NOW(),OLD.regtime);
END


  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值