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的数据)。