首页 > 其他 > 详细

触发器实现源表操作(增,删,改)自动补录操作日志

时间:2018-12-10 13:36:06      阅读:167      评论:0      收藏:0      [点我收藏+]
1:源表数据修改时将修改的数据插入临时表,标记字段为修改
2:源表数据删除时将删除数据插入临时表,编辑字段为删除
3:源表数据新增时将新增数据插入临时表,标记字段为新增
一:定义临时表字段
1:查看源数据testb表
-------------如何修改mysql已经建好表的编码------------------------------
ALTER TABLE  表名 DEFAULT CHARACTER SET utf8 COLLATE utf8_general_ci;
2:创建第一个触发器---插入触发器
 create  trigger tri_userC_insert AFTER insert
 on `usera` FOR EACH ROW
 begin
 insert into userc(idC,nameC,ageC,flogS,flog_time) select id,name,age,‘插入‘,now() from usera where id   not in (select idC from `userc`);
 end
3:创建第二个触发器---更新触发器
 create  trigger tri_userC AFTER update
 on `usera` FOR EACH ROW
 begin
 set @point=(select name from `usera` where id = OLD.id );       
 set @point02=(select age from `usera` where id = OLD.id );
 if @point != old.name then
 update `userc` set nameC=@point where idC=OLD.id;
 update `userc` set flogS=‘更新‘ where idC=OLD.id;
 update `userc` set flog_time=now() where idC=OLD.id;
 end if;
 if @point02 != old.age then
 update `userc` set ageC=@point02 where idC=OLD.id;
 update `userc` set flogS=‘更新‘ where idC=OLD.id;
 update `userc` set flog_time=now() where idC=OLD.id;
 end if;
 end
4:创建第三个触发器---删除触发器
 create  trigger tri_userC_delete AFTER delete
 on `usera` FOR EACH ROW
 begin
 update userc set flogs = ‘删除‘ where idC not in (select id from `usera`);
 update userc set flog_time = now() where idC not in (select id from `usera`);
 end
5:建表语句(A表)
 CREATE TABLE `usera` (
   `id` int(10) NOT NULL,
   `name` varchar(50) DEFAULT NULL,
   `age` int(3) DEFAULT NULL,
   PRIMARY KEY (`id`)
 ) ENGINE=InnoDB DEFAULT CHARSET=utf8;
6:建表语句(C表)
 CREATE TABLE `userc` (
   `idC` int(255) NOT NULL,
   `nameC` varchar(255) DEFAULT NULL,
   `ageC` int(255) DEFAULT NULL,
   `flogs` varchar(255) DEFAULT NULL,
   `flog_time` datetime DEFAULT NULL
 ) ENGINE=InnoDB DEFAULT CHARSET=utf8;
 
 

触发器实现源表操作(增,删,改)自动补录操作日志

原文:https://www.cnblogs.com/zja001/p/10095436.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!