关于mysql 触发器(insert,update)

1. 当表A新增一条记录,表B则跟着添加这条记录

#删除当前触发器
drop TRIGGER IF EXISTS t_edw_event_add_cdr_3;
#创建触发器:当ccbill_cdr表新增一条记录,则在edw_event_add_cdr表添加这条记录
CREATE TRIGGER t_edw_event_add_cdr_3 after INSERT ON ccbill_cdr for EACH ROW
BEGIN
#声明代理商名称变量
DECLARE agentnameA VARCHAR(30);
#根据ccbill_cdr表的userid查询ccbill_ani表的代理商名称
select agentname into agentnameA from ccbill_ani where aniid = new.userid;
#添加记录到edw_event_add_cdr表
INSERT into edw_event_add_cdr (source_id,date_time,status,user_name,trademark,call_status,last_call_time) VALUES (new.callrecid,SYSDATE(),0,new.userid,agentnameA,0,new.endtime);
END

2. 当表A的一条数据发生改变,则把这条记录添加到表B

#删除当前触发器
drop TRIGGER IF EXISTS t_edw_event_chg_balance_2;
#创建触发器:当 ccbill_ani 表余额balance1字段值更新,则把更新数据的记录添加到 edw_event_chg_balance
CREATE TRIGGER t_edw_event_chg_balance_2 before UPDATE on ccbill_ani for EACH ROW
BEGIN
DECLARE newBalance DOUBLE;
DECLARE oldBalance DOUBLE;
set newBalance = new.balance1; #新纪录:已经更新过的余额
set oldBalance = old.balance1; #原记录:更新之前的余额
#select newBalance;
#select oldBalance;
#原来的余额 与 更新后的余额进行对比,如果某一条数据的余额不相等,则说明这条记录已更新,把这条记录添加到 edw_event_chg_balance
if newBalance != oldBalance THEN
  INSERT into edw_event_chg_balance set user_name = new.aniid,trademark = new.agentname,date_time = SYSDATE(),balance = newBalance,status = 0;
end if;
END

 

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值