您的位置:首页 > 其它

表级数据同步:使用snapshot,database link,实现

2013-04-25 17:10 411 查看
是要将库1(源端)中的表replica_test1的数据同步到库2(目标端),用到了dblink,snapshot,snapshot log等技术。

环境准备

 

源、目标端

SQL> create user dbrep identified by dbrep;

SQL> grant connect,resource to dbrep;

SQL> grant create database link to dbrep;

SQL> grant create snapshot to dbrep;

目标库

建立好网络连接,并创建dblink

conn dbrep/dbrep

SQL> create database link source_rep

    connect to dbrep identified by dbrep

    using 'DWH01';

源端:

conn dbrep/dbrep

create table replica_test1(

id number(10) primary key,

name varchar2(50),

job varchar2(50))

;



创建快照日志

SQL> create snapshot log on replica_test1;

目标端:



--创建快照

SQL> create snapshot replica_test1 as

  2  select * from replica_test1@source_rep;

这儿的replica_test1是以物化视图的形式存在。

--刷新方式:设置了1分钟快速刷新

SQL>  alter snapshot replica_test1 refresh fast start with sysdate+1/1440 next sysdate+1/1440  

with primary key;

测试:

在源端

SQL> insert into replica_test1 values(1,'tan','dba');

SQL> commit;

目标端 :

SQL> select * from replica_test1;

一分钟后在目标库查看,出现相应的结果。

快照的刷新有两种方式:快速刷新和完全刷新

快速刷新需要快照的主表先有快照日志存在;

完全刷新时oracle执行快照查询,将结果放入快照。

刷新方式定义和物化视图的一样,不同的是中间有网络,完全刷新网络时间的影响更明显。

  Alter snapshot replica_test1 refresh fast Start with sysdate+1/1440 next sysdate+1/144;

  --此SQL语句的意思为:设定oracle自动在1分钟

  Alter snapshot replica_test1 refresh complete Start with sysdate+1/2880 next sysdate+1;

  --设定oracle自动在30钞,以后每隔1天完全刷新一次。

 
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: