mysql 触发器 监听这个表插入时增加数据 在某字段变动时进行触发

项目触发器

在mysql 表中增加 

需求 当这个表 新增记录的时候触发

DROP TRIGGER IF EXISTS t_make_data; //删除原先的触发器
CREATE TRIGGER t_make_data //创建触发器
BEFORE INSERT ON t_tab1 //触发在这张表新增数据前
FOR EACH ROW
BEGIN  //要执行的sql list 开始
DECLARE number_rand BIGINT(20) DEFAULT 4000 ; 

SET number_rand = (SELECT CAST(RAND()*300+300 AS signed) AS rand);//进行随机数

SET new.number_rand = number_rand;//要在新增的数据中加入数据
END;//要执行的sql list 结束



下面这个是在这个表某个字段发生变动的时候进行触发

DROP TRIGGER IF EXISTS t_make_data;//删除原先的触发器
CREATE TRIGGER t_make_data //创建触发器
BEFORE update ON t_tab1 //触发在这张表修改原先数据前
FOR EACH ROW
BEGIN
DECLARE number_rand BIGINT(20) DEFAULT 100 ; //创建变量

SET number_rand = (SELECT CAST(RAND()*10+10+old.number_rand AS signed) AS rand);//随机数

IF new.number <> old.number then //进行判断如果新的数据 不等于 就的数据
	SET new.number_rand=number_rand; //进行性更新
END IF; //if结束
END; //sql 结束


复制过去 要把注释干掉

希望可以帮当大家 

欢迎讨论和教导







  • 5
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值