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; /
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;
/
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;
/