Oracle触发器备份表数据
作者:网络转载 发布时间:[ 2016/10/26 10:13:30 ] 推荐标签:数据库
1.通过行触发器备份表数据
-- 创建备份表,首次将数据全部备份
create table emp2_bak as select * from emp2;
-- 给备份表增加备份时间和是否被删除字段(1为删除)
alter table emp2_bak add bakTime date;
alter table emp2_bak add deleted number;
-- 创建行触发器:当emp2有数据被删除时,将数据备份到emp2_bak表中,并记录删除时间
create or replace trigger autoBakEmp2
before delete on emp2
for each row
begin
insert into emp2_bak values(:old.empno,:old.ename,:old.job,:old.mgr,:old.hiredate,:old.sal,:old.comm,:old.deptno,sysdate,1);
end;
优点:备份数据教全面(每次删除被备份表数据时,都会自动将删除的记录插入到备份表中)。
缺点:大量删除时备份数据慢,业务数据冗余度高,当有重复数据删除或多次添加删除时,每次都会备份(不会区分差异数据)。
2.通过表级触发器备份表数据
-- 创建备份表
create table emp3_bak as select * from emp3 where 1!=1;
-- 每次删除表数据时,将删除前表数据与备份表数据根据id进行差异比较,如果存在差异,则将差异数据插入到备份表中,否则不处理。
create or replace trigger autoBakEmp3
before delete on emp3
begin
insert into emp3_bak (select * from emp3 where emp3.deptno not in(select deptno from emp3_bak));
end;
优点:数据备份快,数据冗余度低(差异备份)。
缺点:不会备份每次删除的数据(必须保证被备份表的id每次都,删除后不能再添加相同主键id,否则将无法再次备份删除该id的数据)。
相关推荐
更新发布
功能测试和接口测试的区别
2023/3/23 14:23:39如何写好测试用例文档
2023/3/22 16:17:39常用的选择回归测试的方式有哪些?
2022/6/14 16:14:27测试流程中需要重点把关几个过程?
2021/10/18 15:37:44性能测试的七种方法
2021/9/17 15:19:29全链路压测优化思路
2021/9/14 15:42:25性能测试流程浅谈
2021/5/28 17:25:47常见的APP性能测试指标
2021/5/8 17:01:11