本文主要是介绍关于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
这篇关于关于mysql 触发器(insert,update)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!