关于mysql 触发器(insert,update)
来源:互联网 发布:太乙神数排盘软件 编辑:程序博客网 时间:2024/05/22 17:22
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)
- mysql insert与update触发器
- MySQL中的触发器insert、update
- 关于mysql中insert、update、delete的触发器(跨库操作)
- sql触发器(insert,update,delete)
- sql触发器(insert,update,delete)
- SQL触发器编程(insert/update/delete)
- Insert , Update , Delete 触发器
- mysql在insert触发器里update当前数据
- mysql 触发器的使用 FOR INSERT,DELETE,UPDATE
- Mysql在insert触发器里如何update当前数据
- mysql insert触发器事例
- mysql-insert or update
- mysql insert update语句
- MySQL insert update语句
- mysql-insert or update
- mysql update,insert常用
- 1, insert触发器; 2, update触发器; 3, delete触发器;
- 安装Drools后,在Eclipse页面并未显示drools快捷图标
- python getopt使用
- Android ListView的下拉刷新
- 蓝桥杯--马虎的算式
- 选择照片心得
- 关于mysql 触发器(insert,update)
- unix - pipe
- HDU 1796 How many integers can you find 容斥(入门
- Android两种方式获取网络数据
- 基于C#的socket编程的TCP异步实现
- spring+struts整合
- Servlet 页面跳转 并弹出提示对话框
- unix-daemonize()
- Dimension作用?