mysql 触发器示例_MySQL触发器示例(8)

什么是触发器

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

Delimiter $$CREATE trigger tr_users_insert after insert onusersforeach rowbegin

insert intooplog(uid,uname,action,optime)values(NEW.uid,NEW.uname,'insert',now());End;

$$

Delimiter ;

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

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

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

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

5.影响的范围?For each row

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

生产环境触发器实例

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

Delimiter $$CREATE trigger tr_users_delete before delete onusersforeach rowbegin

insert intooplog(uid,uname,action,optime,old_value,new_value)values(OLD.uid,OLD.uname,'delete',now(),OLD.regtime,OLD.regtime);End;

$$

Delimiter ;

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值