我是新手今天头让我试着写一个存储过程
实现定时运行使A表数据与B表中的数据比较
如果B表新增记录对应把新增记录添入A表

解决方案 »

  1.   

    create trigger b_tri
    before insert or update or delete on b
    for each row
    begin
    if inserting then
    insert into a (col1,col2,...) values(:new.col1,:new.col2,...);elsif updating then
    update a set col=:new.col where id=:old.id;
    elsif deleting then
    delete from a where id=:old.id;
    end if;
    end;
    /
      

  2.   

    是的,还是使用触发器安全,因为你B表删除的记录没有及时反映到A表那么
    B的记录就比A表的少了,就不能反映数据的一致:除非你只管新增的数据,或者
    再做一次判断,就是说存储过程处理起来相对麻烦:
    如果要做成过程定期执行,可以使用JOP来实现假设有一个存储过程p_test,每20分钟执行一次
    1、把init<sid>.ora中如下两个参数打开
     JOB_QUEUE_INTERVAL=60
     JOB_QUEUE_PROCESSES=4
     job_queue_keep_connections=true 然后重启一个库,如果原来已经打开了则不用这步了
    2、示例,以下由sqlplus 来执行,具体参照一下相关的文档
     VARIABLE jobno number;
     BEGIN
       DBMS_JOB.SUBMIT(:jobno,
         'p_test;'
         SYSDATE,'SYSDATE + 1/72');
       commit;
     END;DBMS_JOB.SUBMIT(:jobno,//job号
                    'your_procedure;',//要执行的过程
                    trunc(sysdate)+1/24,//下次执行时间
                    'trunc(sysdate)+1/24+1'//每次间隔时间
                   );
    删除job:dbms_job.remove(jobno);
    修改job:dbms_job.what(jobno,what);
    修改下次执行时间:dbms_job.next_date(job,next_date);
    修改间隔时间:dbms_job.interval(job,interval);
    停止job:dbms.broken(job,broken,nextdate);
    启动job:dbms_job.run(jobno);
    例子:
    VARIABLE jobno number;
    begin
          DBMS_JOB.SUBMIT(:jobno,
                  'Procdemo;',
                   SYSDATE, 'SYSDATE + 1/720');
             commit;
    end;
    /